/*!
 * WooKit — Product Sort.
 * Trigger badge + popover (desktop) / bottom drawer (mobile) listing the
 * configured ?orderby= options. The shell is provided by core/trigger.css
 * and core/dropdown.css; this file styles only the popover contents.
 */

/* ── Trigger label (current sort label inside the badge) ──────────── */
.wookit-sort-trigger-label {
	display: inline-flex;
	align-items: baseline;
	gap: 4px;
	white-space: nowrap !important;
	overflow: hidden;
	text-overflow: ellipsis !important;
	max-width: 30ch;
}

.wookit-sort-trigger-label strong {
	font-weight: 600 !important;
	color: var( --wookit-text, inherit ) !important;
}

/* ── Active indicator (dot) ──────────────────────────────────────────────
   Hidden on desktop, where the current-sort text already shows the state.
   On small mobile the type text is hidden, so this dot is the only cue that a
   non-default sort is applied (mirrors the filter's active-count badge). */
.wookit-sort-trigger-badge {
	display: none;
	width: 8px;
	height: 8px;
	border-radius: 999px;
	background: var( --wookit-accent, #1f2937 ) !important;
	transform: scale( 0 );
	transition: transform 180ms cubic-bezier( 0.4, 0, 0.2, 1 );
}
.wookit-sort-trigger-badge.wookit-has-items {
	transform: scale( 1 );
}

/* Compact sort trigger on small mobile: drop the ": <current type>" text,
   keep the base label + show the active dot. */
@media ( max-width: 600px ) {
	.wookit-sort-trigger-sep,
	.wookit-sort-trigger-current {
		display: none !important;
	}
	.wookit-sort-trigger-badge {
		display: inline-block;
	}
}

/* ── Popover sizing ────────────────────────────────────────────────── */
.wookit-sort-dropdown {
	min-width: 240px;
	max-width: 320px;
}

@media ( max-width: 1024px ) {
	.wookit-sort-dropdown {
		max-width: 100%;
	}
}

/* ── Header inside popover ─────────────────────────────────────────── */
.wookit-sort-header {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	padding: 0.875rem 1rem 0.75rem !important;
	margin: 0 !important;
	border-bottom: 1px solid var( --wookit-border, #e5e7eb ) !important;
	font-family: var( --wookit-font, inherit ) !important;
	background: transparent !important;
}

.wookit-sort-title {
	font-size: 0.9375rem !important;
	font-weight: 600 !important;
	color: var( --wookit-text, inherit ) !important;
	text-transform: none !important;
	letter-spacing: normal !important;
	margin: 0 !important;
	padding: 0 !important;
}

/* Close X — themes love slamming buttons with brand bg + caps. Reset hard. */
.wookit-sort-close,
.wookit-sort-close:hover,
.wookit-sort-close:focus,
.wookit-sort-close:active {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 28px !important;
	height: 28px !important;
	min-height: unset !important;
	min-width: unset !important;
	padding: 0 !important;
	margin: 0 !important;
	border: 0 !important;
	background: transparent !important;
	color: var( --wookit-muted, #6b7280 ) !important;
	border-radius: var( --wookit-radius-sm, 4px ) !important;
	cursor: pointer !important;
	font-family: inherit !important;
	font-size: inherit !important;
	font-weight: 500 !important;
	letter-spacing: normal !important;
	text-transform: none !important;
	text-shadow: none !important;
	box-shadow: none !important;
	outline: none !important;
	line-height: 1 !important;
	transition: background-color 120ms ease, color 120ms ease !important;
}

.wookit-sort-close:hover {
	background: var( --wookit-surface-alt, rgba( 0, 0, 0, 0.04 ) ) !important;
	color: var( --wookit-text, inherit ) !important;
}

/* ── Options list ──────────────────────────────────────────────────── */
.wookit-sort-options {
	list-style: none !important;
	margin: 0 !important;
	padding: 0.375rem !important;
	max-height: 60vh;
	overflow-y: auto;
}

.wookit-sort-options li {
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
	background: transparent !important;
}

.wookit-sort-options li::before {
	content: none !important;
	display: none !important;
}

/* Reset the option <button> aggressively — themes often style every button
   with brand bg + uppercase + bold. */
.wookit-sort-option,
.wookit-sort-option:hover,
.wookit-sort-option:focus,
.wookit-sort-option:active {
	width: 100% !important;
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	gap: 0.75rem !important;
	padding: 0.625rem 0.75rem !important;
	margin: 0 !important;
	min-height: unset !important;
	min-width: unset !important;
	font-family: inherit !important;
	font-size: 0.9375rem !important;
	font-weight: 500 !important;
	font-style: normal !important;
	letter-spacing: normal !important;
	text-transform: none !important;
	text-shadow: none !important;
	text-decoration: none !important;
	color: var( --wookit-body, inherit ) !important;
	background: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
	outline: none !important;
	border-radius: var( --wookit-radius-sm, 4px ) !important;
	cursor: pointer !important;
	text-align: left !important;
	line-height: 1.4 !important;
	transition: background-color 120ms ease, color 120ms ease !important;
}

.wookit-sort-option:hover {
	background: var( --wookit-surface-alt, rgba( 0, 0, 0, 0.04 ) ) !important;
	color: var( --wookit-text, inherit ) !important;
}

.wookit-sort-option.is-active,
.wookit-sort-option.is-active:hover {
	color: var( --wookit-accent, currentColor ) !important;
	background: var( --wookit-accent-soft, rgba( 0, 0, 0, 0.04 ) ) !important;
}

.wookit-sort-option-label {
	flex: 1;
	min-width: 0;
}

.wookit-sort-check {
	opacity: 0;
	flex-shrink: 0;
	color: var( --wookit-accent, currentColor ) !important;
	transition: opacity 120ms ease;
}

.wookit-sort-option.is-active .wookit-sort-check {
	opacity: 1;
}

.wookit-sort-widget.is-loading {
	opacity: 0.6;
	pointer-events: none;
}

@media ( prefers-reduced-motion: reduce ) {
	.wookit-sort-option,
	.wookit-sort-close,
	.wookit-sort-check {
		transition: none;
	}
}
