/**
 * Shop Archive Layout & Filter UI
 *
 * Covers:
 *   .alm-archive-wrap        — outer page wrapper
 *   .alm-archive-header      — title row + mobile toggle
 *   .alm-intent-shortcuts    — use-case quick-filter row
 *   .alm-archive             — sidebar + main flex layout
 *   .alm-filter-sidebar      — desktop persistent sidebar (≥ 768px)
 *   .alm-filter-drawer       — mobile slide-in dialog (< 768px)
 *   .alm-filter-toggle       — mobile open button
 *   .alm-filter-form         — filter fieldsets, options, price, stock
 *   .alm-filter-chips        — active filter tag strip
 *   .alm-filter-overlay      — backdrop for mobile drawer
 *   .alm-empty-state         — no-results message
 *   .alm-guidance-cta        — WhatsApp CTA below grid
 *
 * Breakpoints:
 *   Mobile-first.
 *   Desktop layout at 48rem (768px).
 *
 * Loaded only on is_shop() and is_product_taxonomy() — never on single product.
 */

/* ── Outer wrapper ──────────────────────────────────────────────────── */

.alm-archive-wrap {
	padding-block: var(--alm-space-6);
}

/* ── Archive header row ─────────────────────────────────────────────── */

.alm-archive-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--alm-space-4);
	margin-block-end: var(--alm-space-4);
	flex-wrap: wrap;
}

.alm-archive-header__titles {
	flex: 1 1 auto;
	min-width: 0;
}

.alm-archive-header__title {
	font-size: var(--alm-text-2xl, 1.5rem);
	font-weight: 700;
	color: var(--alm-color-navy-primary);
	margin: 0;
	line-height: 1.2;
}

.alm-archive-header__count {
	font-size: var(--alm-text-sm);
	color: var(--alm-color-text-muted);
	margin: var(--alm-space-1) 0 0;
}

/* ── Intent shortcuts ───────────────────────────────────────────────── */

.alm-intent-shortcuts {
	margin-block-end: var(--alm-space-5);
	overflow-x: auto;
	scrollbar-width: none;
}

.alm-intent-shortcuts::-webkit-scrollbar {
	display: none;
}

.alm-intent-shortcuts__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: var(--alm-space-2);
	flex-wrap: nowrap;
}

.alm-intent-shortcut {
	display: inline-flex;
	align-items: center;
	white-space: nowrap;
	padding-block: var(--alm-space-2);
	padding-inline: var(--alm-space-4);
	border: 1px solid var(--alm-color-border);
	border-radius: var(--alm-radius-full, 9999px);
	font-size: var(--alm-text-sm);
	color: var(--alm-color-text-secondary);
	text-decoration: none;
	background: var(--alm-color-white);
	transition: border-color 0.15s, background 0.15s, color 0.15s;
	min-height: 44px;
}

.alm-intent-shortcut:hover {
	border-color: var(--alm-color-navy-primary);
	color: var(--alm-color-navy-primary);
}

.alm-intent-shortcut:focus-visible {
	outline: 2px solid var(--alm-color-sand);
	outline-offset: 2px;
}

.alm-intent-shortcut--active {
	background: var(--alm-color-navy-primary);
	border-color: var(--alm-color-navy-primary);
	color: var(--alm-color-text-inverse);
	font-weight: 600;
}

/* ── Archive flex layout ────────────────────────────────────────────── */

.alm-archive {
	display: flex;
	flex-direction: column;
	gap: var(--alm-space-6);
}

@media (min-width: 48rem) {
	.alm-archive {
		flex-direction: row;
		align-items: flex-start;
		gap: var(--alm-space-8);
	}
}

.alm-archive__main {
	flex: 1 1 0;
	min-width: 0;
}

/* ── Mobile toggle button ───────────────────────────────────────────── */

.alm-filter-toggle {
	display: inline-flex;
	align-items: center;
	gap: var(--alm-space-2);
	position: relative;
}

@media (min-width: 48rem) {
	.alm-filter-toggle {
		display: none;
	}
}

.alm-filter-toggle__badge {
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--alm-color-sand);
	position: absolute;
	top: 6px;
	inset-inline-end: 6px;
}

/* ── Desktop filter sidebar ─────────────────────────────────────────── */

.alm-filter-sidebar {
	display: none;
}

@media (min-width: 48rem) {
	.alm-filter-sidebar {
		display: block;
		width: 240px;
		flex-shrink: 0;
		position: sticky;
		top: calc(var(--alm-header-height, 64px) + var(--alm-space-4));
		max-height: calc(100vh - var(--alm-header-height, 64px) - var(--alm-space-8));
		overflow-y: auto;
		scrollbar-width: thin;
		scrollbar-color: var(--alm-color-border) transparent;
	}
}

.alm-filter-sidebar__heading {
	font-size: var(--alm-text-base);
	font-weight: 700;
	color: var(--alm-color-navy-primary);
	margin: 0 0 var(--alm-space-4);
}

/* ── Mobile filter drawer ───────────────────────────────────────────── */

.alm-filter-drawer {
	position: fixed;
	inset-block: 0;
	inset-inline-end: 0;
	width: min(340px, 92vw);
	background: var(--alm-color-surface-page);
	box-shadow: -4px 0 24px rgba(16, 42, 67, 0.18);
	z-index: var(--alm-z-drawer, 200);
	overflow-y: auto;
	display: flex;
	flex-direction: column;
	transform: translateX(105%);
	transition: transform 0.25s ease;
	visibility: hidden;
}

[dir="ltr"] .alm-filter-drawer {
	inset-inline-end: auto;
	inset-inline-start: 0;
	transform: translateX(-105%);
}

.alm-filter-drawer.is-open {
	transform: translateX(0);
	visibility: visible;
}

@media (min-width: 48rem) {
	.alm-filter-drawer {
		display: none;
	}
}

.alm-filter-drawer__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--alm-space-4) var(--alm-space-5);
	border-bottom: 1px solid var(--alm-color-border);
	flex-shrink: 0;
}

.alm-filter-drawer__heading {
	font-size: var(--alm-text-base);
	font-weight: 700;
	color: var(--alm-color-navy-primary);
	margin: 0;
}

.alm-filter-drawer__close {
	flex-shrink: 0;
}

.alm-filter-drawer__body {
	padding: var(--alm-space-5);
	flex: 1 1 auto;
	overflow-y: auto;
}

/* ── Overlay backdrop ───────────────────────────────────────────────── */

.alm-filter-overlay {
	display: none;
	position: fixed;
	inset: 0;
	background: var(--alm-color-surface-overlay);
	z-index: calc(var(--alm-z-drawer, 200) - 1);
}

.alm-filter-overlay.is-visible {
	display: block;
}

/* ── Filter form ────────────────────────────────────────────────────── */

.alm-filter-form {
	display: flex;
	flex-direction: column;
	gap: var(--alm-space-5);
}

.alm-filter-group {
	border: 0;
	padding: 0;
	margin: 0;
}

.alm-filter-group + .alm-filter-group {
	border-top: 1px solid var(--alm-color-border);
	padding-top: var(--alm-space-5);
}

.alm-filter-group__legend {
	font-family: var(--alm-font-arabic);
	font-size: var(--alm-text-sm);
	font-weight: 600;
	color: var(--alm-color-text-primary);
	margin-block-end: var(--alm-space-3);
	padding: 0;
	width: 100%;
}

/* ── Filter option links ────────────────────────────────────────────── */

.alm-filter-group__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--alm-space-1);
}

.alm-filter-option {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-block: var(--alm-space-2);
	padding-inline: var(--alm-space-2);
	border-radius: var(--alm-radius-sm, 4px);
	font-size: var(--alm-text-sm);
	color: var(--alm-color-text-secondary);
	text-decoration: none;
	transition: background 0.15s, color 0.15s;
	min-height: 44px;
}

.alm-filter-option:hover {
	background: var(--alm-color-surface-subtle);
	color: var(--alm-color-text-primary);
}

.alm-filter-option:focus-visible {
	outline: 2px solid var(--alm-color-sand);
	outline-offset: 2px;
}

.alm-filter-option--active {
	background: var(--alm-color-navy-primary-10);
	color: var(--alm-color-navy-primary);
	font-weight: 600;
}

.alm-filter-option__count {
	font-size: var(--alm-text-xs);
	color: var(--alm-color-text-muted);
	font-weight: 400;
}

/* ── Price inputs ───────────────────────────────────────────────────── */

.alm-filter-price {
	display: grid;
	grid-template-columns: auto 1fr auto 1fr;
	align-items: center;
	gap: var(--alm-space-2);
}

.alm-filter-price__label {
	font-size: var(--alm-text-sm);
	color: var(--alm-color-text-muted);
	white-space: nowrap;
}

.alm-filter-price__input {
	width: 100%;
	padding: var(--alm-space-2);
	border: 1px solid var(--alm-color-border);
	border-radius: var(--alm-radius-sm, 4px);
	font-size: var(--alm-text-sm);
	color: var(--alm-color-text-primary);
	background: var(--alm-color-white);
	-moz-appearance: textfield;
	text-align: center;
}

.alm-filter-price__input::-webkit-inner-spin-button,
.alm-filter-price__input::-webkit-outer-spin-button {
	-webkit-appearance: none;
}

.alm-filter-price__input:focus-visible {
	outline: 2px solid var(--alm-color-sand);
	outline-offset: 2px;
	border-color: var(--alm-color-sand);
}

/* ── Stock checkbox ─────────────────────────────────────────────────── */

.alm-filter-checkbox {
	display: flex;
	align-items: center;
	gap: var(--alm-space-2);
	cursor: pointer;
	min-height: 44px;
}

.alm-filter-checkbox input[type="checkbox"] {
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	accent-color: var(--alm-color-navy-primary);
	cursor: pointer;
}

.alm-filter-checkbox__label {
	font-size: var(--alm-text-sm);
	color: var(--alm-color-text-secondary);
}

/* ── Form actions ───────────────────────────────────────────────────── */

.alm-filter-form__actions {
	display: flex;
	flex-direction: column;
	gap: var(--alm-space-2);
	padding-top: var(--alm-space-4);
}

.alm-filter-form__submit,
.alm-filter-form__clear {
	width: 100%;
	text-align: center;
	justify-content: center;
}

/* ── Active filter chips ────────────────────────────────────────────── */

.alm-filter-chips {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--alm-space-2);
	margin-block-end: var(--alm-space-4);
}

.alm-filter-chips__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--alm-space-2);
}

.alm-filter-chip {
	display: inline-flex;
	align-items: center;
	gap: var(--alm-space-1);
	padding-block: var(--alm-space-1);
	padding-inline: var(--alm-space-3);
	background: var(--alm-color-navy-primary-10);
	border: 1px solid var(--alm-color-navy-primary);
	border-radius: var(--alm-radius-full, 9999px);
	font-size: var(--alm-text-xs);
	color: var(--alm-color-navy-primary);
	text-decoration: none;
	transition: background 0.15s;
}

.alm-filter-chip:hover {
	background: var(--alm-color-navy-primary);
	color: var(--alm-color-text-inverse);
}

.alm-filter-chip:focus-visible {
	outline: 2px solid var(--alm-color-sand);
	outline-offset: 2px;
}

.alm-filter-chip__remove {
	display: flex;
	align-items: center;
	opacity: 0.6;
}

.alm-filter-chip:hover .alm-filter-chip__remove {
	opacity: 1;
}

.alm-filter-chips__clear {
	font-size: var(--alm-text-xs);
	color: var(--alm-color-text-muted);
	text-decoration: underline;
	text-underline-offset: 2px;
	margin-inline-start: var(--alm-space-2);
}

.alm-filter-chips__clear:hover {
	color: var(--alm-color-error);
}

/* ── Empty state ────────────────────────────────────────────────────── */

.alm-empty-state {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding-block: var(--alm-space-12, 3rem);
	gap: var(--alm-space-4);
}

.alm-empty-state__icon {
	color: var(--alm-color-border);
}

.alm-empty-state__title {
	font-size: var(--alm-text-xl, 1.25rem);
	font-weight: 700;
	color: var(--alm-color-navy-primary);
	margin: 0;
}

.alm-empty-state__message {
	font-size: var(--alm-text-base);
	color: var(--alm-color-text-muted);
	max-width: 36ch;
	margin: 0;
}

.alm-empty-state__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--alm-space-3);
}

/* ── Guidance CTA ───────────────────────────────────────────────────── */

.alm-guidance-cta {
	margin-block-start: var(--alm-space-10, 2.5rem);
	padding: var(--alm-space-6);
	background: var(--alm-color-surface-subtle);
	border-radius: var(--alm-radius-md, 8px);
	border: 1px solid var(--alm-color-border);
}

.alm-guidance-cta__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--alm-space-4);
	flex-wrap: wrap;
}

.alm-guidance-cta__title {
	font-size: var(--alm-text-base);
	font-weight: 700;
	color: var(--alm-color-navy-primary);
	margin: 0 0 var(--alm-space-1);
}

.alm-guidance-cta__text {
	font-size: var(--alm-text-sm);
	color: var(--alm-color-text-secondary);
	margin: 0;
	max-width: 48ch;
}

.alm-guidance-cta__action {
	flex-shrink: 0;
	white-space: nowrap;
}

/* ── Reduced motion ─────────────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
	.alm-filter-drawer,
	.alm-intent-shortcut,
	.alm-filter-option,
	.alm-filter-chip {
		transition: none;
	}
}

/* ═══════════════════════════════════════════════════════════════════
   SHOP ARCHIVE V2 — DISCOVERY + FILTER FOUNDATION
   Added as a scoped override layer; existing rules remain intact.
   ══════════════════════════════════════════════════════════════════ */

.alm-archive-wrap[data-alm-shop-archive] {
	padding-block: 0 clamp(4rem, 7vw, 7rem);
	background:
		linear-gradient(180deg, #F7F3EE 0, #FCFBF9 25rem, #FCFBF9 100%);
}

.alm-archive-header {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1.25fr) minmax(17rem, 0.55fr);
	gap: clamp(2rem, 6vw, 6rem);
	align-items: end;
	margin-block-end: 0;
	padding-block: clamp(3rem, 7vw, 6.5rem);
	border-block-end: 1px solid rgba(16, 42, 67, 0.12);
}

.alm-archive-header::before {
	content: "";
	position: absolute;
	inset-block-start: 0;
	inset-inline-end: calc(50% - 50vw);
	inline-size: clamp(8rem, 18vw, 18rem);
	block-size: 100%;
	background:
		linear-gradient(135deg, rgba(205, 170, 125, 0.18), transparent 66%);
	pointer-events: none;
}

.alm-archive-header__content {
	position: relative;
	z-index: 1;
	max-width: 52rem;
}

.alm-archive-header__eyebrow,
.alm-archive-header__aside-label {
	display: block;
	margin: 0 0 0.75rem;
	color: var(--alm-color-copper-deep);
	font-size: var(--alm-text-xs);
	font-weight: var(--alm-weight-bold);
	letter-spacing: 0.06em;
}

.alm-archive-header__title {
	max-width: 14ch;
	margin: 0;
	font-size: clamp(2.4rem, 5.5vw, 5.2rem);
	line-height: 1.02;
	letter-spacing: -0.035em;
}

.alm-archive-header__description {
	max-width: 43rem;
	margin-block-start: var(--alm-space-5);
	color: var(--alm-color-text-secondary);
	font-size: var(--alm-text-md);
	line-height: 1.9;
}

.alm-archive-header__description p {
	margin: 0;
}

.alm-archive-header__signals {
	display: flex;
	flex-wrap: wrap;
	gap: var(--alm-space-3) var(--alm-space-5);
	margin: var(--alm-space-6) 0 0;
	padding: 0;
	list-style: none;
}

.alm-archive-header__signals li {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	color: var(--alm-color-text-primary);
	font-size: var(--alm-text-sm);
	font-weight: var(--alm-weight-semibold);
}

.alm-archive-header__signals li > span {
	inline-size: 0.48rem;
	block-size: 0.48rem;
	border-radius: 50%;
	background: var(--alm-color-sand);
	box-shadow: 0 0 0 0.28rem rgba(205, 170, 125, 0.14);
}

.alm-archive-header__aside {
	position: relative;
	z-index: 1;
	display: grid;
	gap: var(--alm-space-4);
	padding: clamp(1.35rem, 3vw, 2rem);
	border-inline-start: 3px solid var(--alm-color-sand);
	background: rgba(255, 255, 255, 0.76);
	box-shadow: 0 18px 48px rgba(16, 42, 67, 0.06);
}

.alm-archive-header__aside strong {
	color: var(--alm-color-navy-primary);
	font-size: clamp(1.05rem, 1.8vw, 1.35rem);
	line-height: 1.55;
}

.alm-filter-toggle__count {
	display: inline-grid;
	place-items: center;
	min-inline-size: 1.7rem;
	block-size: 1.7rem;
	padding-inline: 0.35rem;
	border-radius: 999px;
	background: var(--alm-color-navy-primary);
	color: var(--alm-color-white);
	font-family: var(--alm-font-latin);
	font-size: 0.72rem;
	font-weight: var(--alm-weight-bold);
}

.alm-intent-shortcuts {
	display: grid;
	grid-template-columns: minmax(13rem, 0.28fr) minmax(0, 1.72fr);
	gap: clamp(1.5rem, 4vw, 3.5rem);
	align-items: center;
	margin-block: 0;
	padding-block: clamp(1.75rem, 4vw, 3rem);
	border-block-end: 1px solid rgba(16, 42, 67, 0.12);
	overflow: visible;
}

.alm-intent-shortcuts__intro {
	display: grid;
	grid-template-columns: auto 1fr;
	align-items: start;
	gap: var(--alm-space-3);
}

.alm-intent-shortcuts__index {
	color: var(--alm-color-copper-deep);
	font-family: var(--alm-font-latin);
	font-size: 0.72rem;
	font-weight: var(--alm-weight-bold);
	letter-spacing: 0.08em;
}

.alm-intent-shortcuts__intro h2 {
	margin: 0;
	color: var(--alm-color-navy-primary);
	font-size: var(--alm-text-md);
	line-height: 1.4;
}

.alm-intent-shortcuts__intro p {
	margin: 0.35rem 0 0;
	color: var(--alm-color-text-muted);
	font-size: var(--alm-text-xs);
	line-height: 1.6;
}

.alm-intent-shortcuts nav {
	min-width: 0;
	overflow-x: auto;
	scrollbar-width: none;
}

.alm-intent-shortcuts nav::-webkit-scrollbar {
	display: none;
}

.alm-intent-shortcuts__list {
	gap: var(--alm-space-3);
}

.alm-intent-shortcut {
	display: grid;
	grid-template-columns: minmax(9rem, 1fr) auto;
	grid-template-areas:
		"label arrow"
		"meta arrow";
	gap: 0.25rem 1rem;
	min-inline-size: 13.5rem;
	min-height: 5rem;
	padding: 1rem 1.1rem;
	border-radius: 0;
	background: rgba(255, 255, 255, 0.7);
}

.alm-intent-shortcut__label {
	grid-area: label;
	color: inherit;
	font-weight: var(--alm-weight-bold);
}

.alm-intent-shortcut__meta {
	grid-area: meta;
	color: var(--alm-color-text-muted);
	font-size: var(--alm-text-xs);
}

.alm-intent-shortcut__arrow {
	grid-area: arrow;
	align-self: center;
	display: inline-grid;
	place-items: center;
	inline-size: 2rem;
	block-size: 2rem;
	border: 1px solid rgba(16, 42, 67, 0.13);
	border-radius: 50%;
}

.alm-intent-shortcut--active .alm-intent-shortcut__meta {
	color: rgba(255, 255, 255, 0.62);
}

.alm-intent-shortcut--active .alm-intent-shortcut__arrow {
	border-color: rgba(255, 255, 255, 0.24);
	color: var(--alm-color-sand);
}

.alm-archive {
	margin-block-start: clamp(2rem, 5vw, 4rem);
	gap: clamp(2rem, 4vw, 3.5rem);
}

.alm-archive__toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--alm-space-4);
	min-height: 4.5rem;
	margin-block-end: var(--alm-space-5);
	padding-block: var(--alm-space-3);
	border-block: 1px solid rgba(16, 42, 67, 0.12);
}

.alm-archive__toolbar::after {
	content: "";
	display: block;
	clear: both;
}

.alm-archive__toolbar .woocommerce-result-count,
.alm-archive__toolbar .woocommerce-ordering {
	float: none;
	margin: 0;
}

.alm-archive__toolbar .woocommerce-result-count {
	color: var(--alm-color-text-muted);
	font-size: var(--alm-text-sm);
}

.alm-archive__toolbar .woocommerce-ordering select {
	min-height: 2.9rem;
	border-color: rgba(16, 42, 67, 0.14);
	background-color: var(--alm-color-white);
}

.alm-filter-sidebar {
	width: clamp(16rem, 22vw, 18.5rem);
	border: 1px solid rgba(16, 42, 67, 0.12);
	background: rgba(255, 255, 255, 0.78);
	overflow: visible;
}

.alm-filter-sidebar__header,
.alm-filter-drawer__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--alm-space-4);
	padding: 1.2rem 1.25rem;
	border-block-end: 1px solid rgba(16, 42, 67, 0.12);
	background: rgba(16, 42, 67, 0.025);
}

.alm-filter-sidebar__eyebrow,
.alm-filter-drawer__eyebrow {
	display: block;
	margin-block-end: 0.25rem;
	color: var(--alm-color-copper-deep);
	font-size: 0.68rem;
	font-weight: var(--alm-weight-bold);
	letter-spacing: 0.06em;
}

.alm-filter-sidebar__heading,
.alm-filter-drawer__heading {
	margin: 0;
	font-size: var(--alm-text-base);
}

.alm-filter-sidebar__clear {
	color: var(--alm-color-text-muted);
	font-size: var(--alm-text-xs);
	text-decoration: underline;
	text-underline-offset: 0.2em;
}

.alm-filter-sidebar__body {
	max-height: calc(100vh - var(--alm-header-height, 64px) - 9rem);
	overflow-y: auto;
	scrollbar-width: thin;
}

.alm-filter-form {
	gap: 0;
}

.alm-filter-group {
	padding: 1.25rem;
}

.alm-filter-group + .alm-filter-group {
	padding-block-start: 1.25rem;
}

.alm-filter-group__legend {
	margin-block-end: 0.8rem;
	color: var(--alm-color-navy-primary);
	font-weight: var(--alm-weight-bold);
}

.alm-filter-option {
	padding-inline: 0;
	border-radius: 0;
	border-block-end: 1px solid rgba(16, 42, 67, 0.07);
}

.alm-filter-option:last-child {
	border-block-end: 0;
}

.alm-filter-option__label {
	min-width: 0;
}

.alm-filter-option__count {
	display: inline-grid;
	place-items: center;
	min-inline-size: 1.8rem;
	block-size: 1.8rem;
	border-radius: 999px;
	background: rgba(16, 42, 67, 0.05);
	font-family: var(--alm-font-latin);
}

.alm-filter-option--active .alm-filter-option__count {
	background: var(--alm-color-navy-primary);
	color: var(--alm-color-white);
}

.alm-filter-price {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
	gap: 0.6rem;
}

.alm-filter-price__field {
	display: grid;
	gap: 0.45rem;
}

.alm-filter-price__field label {
	color: var(--alm-color-text-muted);
	font-size: var(--alm-text-xs);
}

.alm-filter-price__separator {
	align-self: end;
	padding-block-end: 0.75rem;
	color: var(--alm-color-text-muted);
}

.alm-filter-price__input {
	min-width: 0;
	min-height: 2.8rem;
}

.alm-filter-checkbox {
	position: relative;
}

.alm-filter-checkbox input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.alm-filter-checkbox__control {
	display: inline-grid;
	place-items: center;
	inline-size: 1.25rem;
	block-size: 1.25rem;
	border: 1px solid rgba(16, 42, 67, 0.28);
	background: var(--alm-color-white);
	flex: 0 0 auto;
}

.alm-filter-checkbox input:checked + .alm-filter-checkbox__control {
	border-color: var(--alm-color-navy-primary);
	background:
		linear-gradient(135deg, transparent 42%, var(--alm-color-white) 42% 55%, transparent 55%),
		var(--alm-color-navy-primary);
}

.alm-filter-checkbox input:focus-visible + .alm-filter-checkbox__control {
	outline: 2px solid var(--alm-color-sand);
	outline-offset: 2px;
}

.alm-filter-form__actions {
	position: sticky;
	inset-block-end: 0;
	z-index: 2;
	padding: 1rem 1.25rem;
	border-block-start: 1px solid rgba(16, 42, 67, 0.12);
	background: rgba(255, 255, 255, 0.96);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}

.alm-filter-chips {
	display: grid;
	gap: var(--alm-space-3);
	margin-block-end: var(--alm-space-5);
	padding: 1rem 1.1rem;
	border: 1px solid rgba(16, 42, 67, 0.12);
	background: rgba(255, 255, 255, 0.72);
}

.alm-filter-chips__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--alm-space-4);
}

.alm-filter-chips__header h2 {
	margin: 0;
	color: var(--alm-color-navy-primary);
	font-size: var(--alm-text-sm);
}

.alm-filter-chips__list {
	gap: 0.55rem;
}

.alm-filter-chip {
	border-radius: 0;
	border-color: rgba(16, 42, 67, 0.13);
	background: var(--alm-color-white);
}

.alm-filter-chip__prefix {
	color: var(--alm-color-text-muted);
}

.alm-filter-chip__label {
	font-weight: var(--alm-weight-bold);
}

.alm-archive__pagination {
	margin-block-start: clamp(2rem, 5vw, 4rem);
	padding-block-start: var(--alm-space-6);
	border-block-start: 1px solid rgba(16, 42, 67, 0.12);
}

@media (max-width: 74.99rem) {
	.alm-archive-header {
		grid-template-columns: 1fr;
		align-items: start;
	}

	.alm-archive-header__aside {
		max-width: 30rem;
	}

	.alm-intent-shortcuts {
		grid-template-columns: 1fr;
	}

	.alm-intent-shortcuts__intro {
		max-width: 20rem;
	}
}

@media (max-width: 47.99rem) {
	.alm-archive-header {
		padding-block: 2.75rem;
	}

	.alm-archive-header__title {
		max-width: none;
		font-size: clamp(2.2rem, 11vw, 3.35rem);
	}

	.alm-archive-header__signals {
		display: grid;
	}

	.alm-filter-toggle {
		display: inline-flex;
		width: 100%;
		justify-content: center;
	}

	.alm-intent-shortcuts {
		margin-inline: calc(50% - 50vw);
		padding-inline: 1rem;
	}

	.alm-intent-shortcuts__list {
		padding-inline-end: 1rem;
	}

	.alm-archive__toolbar {
		align-items: stretch;
		flex-direction: column;
	}

	.alm-archive__toolbar .woocommerce-ordering,
	.alm-archive__toolbar .woocommerce-ordering select {
		width: 100%;
	}

	.alm-filter-drawer {
		width: min(24rem, 94vw);
	}

	.alm-filter-drawer__body {
		padding: 0;
	}

	.alm-filter-chips {
		margin-inline: calc(50% - 50vw);
		padding-inline: 1rem;
		border-inline: 0;
	}
}

/* ═══════════════════════════════════════════════════════════════════
   SHOP ARCHIVE V3 — CONVERSION STATES
   Empty results, guidance, and pagination only.
   ══════════════════════════════════════════════════════════════════ */

.alm-empty-state {
	display: grid;
	grid-template-columns: minmax(9rem, 0.32fr) minmax(0, 1fr);
	align-items: stretch;
	gap: 0;
	min-height: 28rem;
	margin-block: clamp(2rem, 5vw, 4rem);
	padding: 0;
	border: 1px solid rgba(16, 42, 67, 0.12);
	background: var(--alm-color-white);
	text-align: start;
}

.alm-empty-state__visual {
	position: relative;
	display: grid;
	place-items: center;
	min-height: 100%;
	overflow: hidden;
	background:
		radial-gradient(circle at 70% 25%, rgba(205, 170, 125, 0.2), transparent 10rem),
		linear-gradient(145deg, #243b53, #102a43);
	color: rgba(255, 255, 255, 0.55);
}

.alm-empty-state__visual::before,
.alm-empty-state__visual::after {
	content: "";
	position: absolute;
	border: 1px solid rgba(255, 255, 255, 0.08);
	transform: rotate(45deg);
}

.alm-empty-state__visual::before {
	inline-size: 9rem;
	block-size: 9rem;
}

.alm-empty-state__visual::after {
	inline-size: 14rem;
	block-size: 14rem;
}

.alm-empty-state__visual svg {
	position: relative;
	z-index: 1;
}

.alm-empty-state__visual-index {
	position: absolute;
	inset-block-start: 1rem;
	inset-inline-start: 1rem;
	color: var(--alm-color-sand);
	font-family: var(--alm-font-latin);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.08em;
}

.alm-empty-state__content {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
	gap: var(--alm-space-4);
	padding: clamp(1.5rem, 5vw, 4rem);
}

.alm-empty-state__eyebrow,
.alm-guidance-cta__eyebrow {
	margin: 0;
	color: var(--alm-color-copper-deep);
	font-size: var(--alm-text-xs);
	font-weight: 700;
	letter-spacing: 0.05em;
}

.alm-empty-state__title {
	max-width: 18ch;
	margin: 0;
	font-size: clamp(1.65rem, 3.2vw, 2.8rem);
	line-height: 1.25;
}

.alm-empty-state__message {
	max-width: 45rem;
	margin: 0;
	font-size: var(--alm-text-base);
	line-height: 1.9;
}

.alm-empty-state__actions {
	justify-content: flex-start;
	margin-block-start: var(--alm-space-2);
}

.alm-empty-state__hints {
	display: grid;
	gap: 0.65rem;
	margin: var(--alm-space-3) 0 0;
	padding: var(--alm-space-4) 0 0;
	border-block-start: 1px solid rgba(16, 42, 67, 0.12);
	color: var(--alm-color-text-muted);
	font-size: var(--alm-text-sm);
	line-height: 1.7;
	list-style: none;
}

.alm-empty-state__hints li {
	position: relative;
	padding-inline-start: 1.1rem;
}

.alm-empty-state__hints li::before {
	content: "";
	position: absolute;
	inset-inline-start: 0;
	inset-block-start: 0.75em;
	inline-size: 0.38rem;
	block-size: 0.38rem;
	border-radius: 50%;
	background: var(--alm-color-sand);
}

.alm-guidance-cta {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr) minmax(12rem, auto);
	align-items: center;
	gap: clamp(1.25rem, 3vw, 2.5rem);
	margin-block-start: clamp(3rem, 6vw, 5rem);
	padding: clamp(1.5rem, 4vw, 2.75rem);
	border: 1px solid rgba(16, 42, 67, 0.13);
	border-radius: 0;
	background:
		linear-gradient(135deg, rgba(205, 170, 125, 0.11), transparent 35%),
		var(--alm-color-white);
}

.alm-guidance-cta__marker {
	display: grid;
	place-items: center;
	inline-size: clamp(3.5rem, 6vw, 5.25rem);
	block-size: clamp(3.5rem, 6vw, 5.25rem);
	border: 1px solid rgba(16, 42, 67, 0.14);
	background: var(--alm-color-navy-primary);
	color: var(--alm-color-sand);
}

.alm-guidance-cta__marker span {
	font-family: var(--alm-font-latin);
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 300;
}

.alm-guidance-cta__content {
	min-width: 0;
}

.alm-guidance-cta__title {
	margin: 0.35rem 0 0;
	font-size: clamp(1.25rem, 2.3vw, 1.8rem);
	line-height: 1.4;
}

.alm-guidance-cta__text {
	max-width: 52rem;
	margin-block-start: 0.55rem;
	line-height: 1.8;
}

.alm-guidance-cta__action-wrap {
	display: grid;
	gap: 0.65rem;
	justify-items: stretch;
	min-width: 12rem;
}

.alm-guidance-cta__action-wrap > span {
	color: var(--alm-color-text-muted);
	font-size: 0.68rem;
	line-height: 1.5;
	text-align: center;
}

.alm-guidance-cta__action {
	justify-content: center;
	white-space: nowrap;
}

.alm-archive__pagination .woocommerce-pagination {
	display: flex;
	justify-content: center;
}

.alm-archive__pagination .woocommerce-pagination ul.page-numbers {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0.45rem;
	margin: 0;
	padding: 0;
	border: 0;
	list-style: none;
}

.alm-archive__pagination .woocommerce-pagination ul.page-numbers li {
	margin: 0;
	border: 0;
}

.alm-archive__pagination .page-numbers a,
.alm-archive__pagination .page-numbers span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45rem;
	min-inline-size: 2.75rem;
	min-height: 2.75rem;
	padding-inline: 0.8rem;
	border: 1px solid rgba(16, 42, 67, 0.13);
	background: var(--alm-color-white);
	color: var(--alm-color-navy-primary);
	font-family: var(--alm-font-latin);
	font-size: var(--alm-text-sm);
	text-decoration: none;
}

.alm-archive__pagination .page-numbers a:hover,
.alm-archive__pagination .page-numbers a:focus-visible {
	border-color: var(--alm-color-navy-primary);
	background: var(--alm-color-navy-primary);
	color: var(--alm-color-white);
}

.alm-archive__pagination .page-numbers .current {
	border-color: var(--alm-color-sand);
	background: var(--alm-color-sand);
	color: var(--alm-color-navy-primary);
	font-weight: 700;
}

.alm-archive__pagination .page-numbers .prev,
.alm-archive__pagination .page-numbers .next {
	padding-inline: 1rem;
	font-family: var(--alm-font-arabic);
}

@media (max-width: 47.99rem) {
	.alm-empty-state {
		grid-template-columns: 1fr;
		min-height: 0;
	}

	.alm-empty-state__visual {
		min-height: 13rem;
	}

	.alm-empty-state__content {
		padding: 1.35rem;
	}

	.alm-empty-state__title {
		max-width: none;
	}

	.alm-empty-state__actions {
		display: grid;
		width: 100%;
	}

	.alm-empty-state__actions .alm-btn {
		width: 100%;
		justify-content: center;
	}

	.alm-guidance-cta {
		grid-template-columns: auto minmax(0, 1fr);
	}

	.alm-guidance-cta__action-wrap {
		grid-column: 1 / -1;
	}

	.alm-archive__pagination .page-numbers a,
	.alm-archive__pagination .page-numbers span {
		min-inline-size: 2.5rem;
		min-height: 2.5rem;
		padding-inline: 0.65rem;
	}

	.alm-archive__pagination .page-numbers .prev span:not([aria-hidden]),
	.alm-archive__pagination .page-numbers .next span:not([aria-hidden]) {
		display: none;
	}
}

@media (prefers-reduced-motion: reduce) {
	.alm-archive__pagination .page-numbers a {
		transition: none;
	}
}

/* ═══════════════════════════════════════════════════════════════════
   SHOP ARCHIVE V4 — LAYOUT INTEGRATION FIX
   Container + archive-specific grid only.
   ══════════════════════════════════════════════════════════════════ */

.alm-archive-wrap[data-alm-shop-archive] > .alm-container {
	width: min(100% - 2rem, var(--alm-container-max, 90rem));
	margin-inline: auto;
}

.alm-archive__main ul.products {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(1rem, 2vw, 1.5rem);
}

.alm-archive__main ul.products > li.product {
	width: 100%;
	max-width: none;
	min-width: 0;
}

@media (max-width: 74.99rem) {
	.alm-archive__main ul.products {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 47.99rem) {
	.alm-archive-wrap[data-alm-shop-archive] > .alm-container {
		width: min(100% - 1rem, var(--alm-container-max, 90rem));
	}

	.alm-archive__main ul.products {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 0.85rem;
	}
}

@media (max-width: 24rem) {
	.alm-archive__main ul.products {
		grid-template-columns: 1fr;
	}
}

/* ═══════════════════════════════════════════════════════════════════
   RELATED CATEGORIES — section L
   ══════════════════════════════════════════════════════════════════ */

.alm-related-categories {
	margin-block-start: clamp(3rem, 6vw, 5rem);
	padding-block-start: clamp(2rem, 4vw, 3.5rem);
	border-block-start: 1px solid rgba(16, 42, 67, 0.12);
}

.alm-related-categories__eyebrow {
	margin: 0 0 0.5rem;
	color: var(--alm-color-copper-deep, #8b5e2f);
	font-size: var(--alm-text-xs);
	font-weight: 700;
	letter-spacing: 0.06em;
}

.alm-related-categories__title {
	margin: 0 0 clamp(1.5rem, 3vw, 2.5rem);
	font-size: clamp(1.35rem, 2.5vw, 2rem);
	line-height: 1.3;
	color: var(--alm-color-navy-primary);
}

.alm-related-categories__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(min(100%, 11rem), 1fr));
	gap: clamp(0.75rem, 1.5vw, 1.25rem);
}

.alm-related-category__link {
	display: grid;
	grid-template-rows: auto 1fr auto;
	align-items: center;
	gap: 0.65rem;
	padding: clamp(1rem, 2vw, 1.5rem);
	border: 1px solid rgba(16, 42, 67, 0.11);
	background: var(--alm-color-white);
	color: var(--alm-color-navy-primary);
	text-decoration: none;
	transition: border-color 0.15s, box-shadow 0.15s;
}

.alm-related-category__link:hover {
	border-color: var(--alm-color-sand);
	box-shadow: 0 8px 24px rgba(16, 42, 67, 0.07);
}

.alm-related-category__link:focus-visible {
	outline: 2px solid var(--alm-color-sand);
	outline-offset: 2px;
}

.alm-related-category__image {
	display: block;
	width: 3.5rem;
	height: 3.5rem;
	overflow: hidden;
}

.alm-related-category__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.alm-related-category__icon {
	display: grid;
	place-items: center;
	width: 3.5rem;
	height: 3.5rem;
	background: rgba(16, 42, 67, 0.05);
	color: var(--alm-color-navy-primary);
}

.alm-related-category__name {
	font-size: var(--alm-text-sm);
	font-weight: 700;
	line-height: 1.4;
}

.alm-related-category__count {
	font-size: var(--alm-text-xs);
	color: var(--alm-color-text-muted);
	font-family: var(--alm-font-latin);
}

@media (prefers-reduced-motion: reduce) {
	.alm-related-category__link {
		transition: none;
	}
}
