/**
 * Product category / tag / shop archive — full-width product grid (Flatsome).
 * Requires body.q8kart-product-archive-fullwidth (see functions.php).
 */
@media screen and (min-width: 850px) {
	body.q8kart-product-archive-fullwidth.woocommerce-page #main {
		max-width: none !important;
		width: 100%;
	}

	body.q8kart-product-archive-fullwidth.woocommerce-page #main .row.category-page-row {
		max-width: none !important;
		width: 100%;
		box-sizing: border-box;
		padding-left: clamp(12px, 2.5vw, 40px);
		padding-right: clamp(12px, 2.5vw, 40px);
		margin-left: auto;
		margin-right: auto;
	}

	body.q8kart-product-archive-fullwidth.woocommerce-page #main .shop-container {
		max-width: none !important;
		width: 100%;
		padding-left: 0;
		padding-right: 0;
		box-sizing: border-box;
	}

	/* Toolbar / notices inside shop container */
	body.q8kart-product-archive-fullwidth.woocommerce-page #main .woocommerce-notices-wrapper:first-child {
		margin-bottom: 0.75rem;
	}
}

/**
 * Flatsome shop “Filter” opens #shop-sidebar in Magnific Popup on small viewports.
 * Filter Everything “Show bottom widget” / open-close mobile CSS keeps .wpc-filters-widget-content
 * translated below the viewport until its own button adds .wpc-filters-widget-opened — so the panel
 * looks empty. Reset that layout when the widget is inside the popup (max-width matches Flatsome
 * hide-for-medium / shop sidebar breakpoint).
 */
@media screen and (max-width: 849px) {
	/**
	 * One mobile filter entry: Flatsome “Filter” opens #shop-sidebar.
	 * Hide Filter Everything’s duplicate open button (woocommerce_before_shop_loop).
	 * Selected terms appear beside Filter via child `woocommerce/loop/filter-button.php` + [fe_chips].
	 */
	body.woocommerce-page.archive:not(.single-product).wpc_show_bottom_widget .wpc-filters-open-button-container,
	body.woocommerce-page.archive:not(.single-product).wpc_show_open_close_button .wpc-filters-open-button-container {
		display: none !important;
	}

	.mfp-content #shop-sidebar .widget_wpc_filters_widget .wpc-filters-widget-content,
	.mfp-content #shop-sidebar .wpc-filters-main-wrap .wpc-filters-widget-content {
		transform: translate3d(0, 0, 0) !important;
		position: relative !important;
		top: auto !important;
		bottom: auto !important;
		left: auto !important;
		right: auto !important;
		z-index: auto !important;
		height: auto !important;
		max-height: none !important;
		border-radius: 0 !important;
		display: block !important;
		overflow: visible !important;
	}

	.mfp-content #shop-sidebar .widget_wpc_filters_widget .wpc-filters-widget-containers-wrapper,
	.mfp-content #shop-sidebar .wpc-filters-main-wrap .wpc-filters-widget-containers-wrapper {
		position: relative !important;
		top: auto !important;
		bottom: auto !important;
		left: auto !important;
		right: auto !important;
		overflow-y: auto !important;
		max-height: min(70vh, 28rem) !important;
		-webkit-overflow-scrolling: touch;
	}
}

/* Filter Everything selected terms beside Flatsome “Filter” (see woocommerce/loop/filter-button.php). */
body.woocommerce-page .category-filter-row .q8kart-shop-filter-inline-chips {
	flex: 1 1 0;
	min-width: 0;
	max-width: 100%;
}

body.woocommerce-page .category-filter-row .q8kart-shop-filter-inline-chips .wpc-custom-selected-terms {
	margin: 0;
}

/* -------------------------------------------------------------------------
 * Mobile shop pill: Sort By | Filter (body.q8kart-shop-mobile-pill) + drawer
 * ------------------------------------------------------------------------- */
@media screen and (min-width: 850px) {
	#q8kart-shop-mobile-bar {
		display: none !important;
	}

	.q8kart-shop-sort-sheet {
		display: none !important;
	}
}

@media screen and (max-width: 849px) {
	body.q8kart-shop-mobile-pill .shop-page-title .category-filtering {
		display: none !important;
	}

	body.q8kart-shop-mobile-pill .shop-page-title .page-title-inner > .flex-col:last-child {
		display: none !important;
	}

	body.q8kart-shop-mobile-pill.q8kart-mobile-tabbar:not(.single-product) {
		padding-bottom: calc(var(--q8-mobile-tabbar-h, 56px) + 50px + env(safe-area-inset-bottom, 0px)) !important;
	}

	body.q8kart-shop-mobile-pill:not(.q8kart-mobile-tabbar):not(.single-product) {
		padding-bottom: calc(50px + env(safe-area-inset-bottom, 0px));
	}

	#q8kart-shop-mobile-bar {
		display: none;
		align-items: stretch;
		justify-content: stretch;
		gap: 0;
		position: fixed;
		left: max(12px, env(safe-area-inset-left, 0px));
		right: max(12px, env(safe-area-inset-right, 0px));
		z-index: 980;
		height: 40px;
		border-radius: 999px;
		overflow: hidden;
		box-shadow: 0 3px 14px rgba(0, 0, 0, 0.16);
		background: var(--fs-color-primary, #2e1a6d);
		color: #fff;
		font-size: 0.75rem;
		font-weight: 700;
		letter-spacing: 0.02em;
	}

	body.q8kart-shop-mobile-pill #q8kart-shop-mobile-bar {
		display: flex;
	}

	body.q8kart-mobile-tabbar.q8kart-shop-mobile-pill #q8kart-shop-mobile-bar {
		bottom: calc(var(--q8-mobile-tabbar-h, 56px) + 10px + env(safe-area-inset-bottom, 0px));
	}

	body.q8kart-shop-mobile-pill:not(.q8kart-mobile-tabbar) #q8kart-shop-mobile-bar {
		bottom: calc(12px + env(safe-area-inset-bottom, 0px));
	}

	#q8kart-shop-mobile-bar .q8kart-shop-mobile-bar__segment {
		flex: 1 1 50%;
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 0.28rem;
		cursor: pointer;
		color: inherit;
		text-decoration: none;
		-webkit-tap-highlight-color: transparent;
		user-select: none;
		position: relative;
		z-index: 1;
	}

	#q8kart-shop-mobile-bar button.q8kart-shop-mobile-bar__sort {
		border: 0;
		margin: 0;
		padding: 0;
		width: 100%;
		height: 100%;
		background: transparent;
		color: inherit;
		font: inherit;
		font-weight: inherit;
		letter-spacing: inherit;
		text-align: center;
		appearance: none;
		-webkit-appearance: none;
	}

	#q8kart-shop-mobile-bar .q8kart-shop-mobile-bar__sort:active,
	#q8kart-shop-mobile-bar .q8kart-shop-mobile-bar__filter:active {
		filter: brightness(1.08);
	}

	#q8kart-shop-mobile-bar .q8kart-shop-mobile-bar__split {
		width: 1px;
		align-self: stretch;
		margin: 5px 0;
		background: rgba(255, 255, 255, 0.45);
		flex: 0 0 auto;
		position: relative;
		z-index: 1;
	}

	/* Ordering <form> moved into bar by shop-mobile-filter-bar.js (was inside display:none title column). */
	#q8kart-shop-mobile-bar > form.woocommerce-ordering.q8kart-shop-mobile-bar__ordering-form {
		position: absolute;
		left: 0;
		top: 0;
		width: 50%;
		height: 100%;
		margin: 0;
		padding: 0;
		border: 0;
		opacity: 0;
		overflow: visible;
		z-index: 0;
	}

	#q8kart-shop-mobile-bar > form.woocommerce-ordering.q8kart-shop-mobile-bar__ordering-form label {
		position: absolute;
		width: 1px;
		height: 1px;
		padding: 0;
		margin: -1px;
		overflow: hidden;
		clip: rect(0, 0, 0, 0);
		white-space: nowrap;
		border: 0;
	}

	#q8kart-shop-mobile-bar > form.woocommerce-ordering.q8kart-shop-mobile-bar__ordering-form select.orderby {
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		height: 100%;
		margin: 0;
		padding: 0;
		border: 0;
		font-size: 16px;
		background: transparent;
		color: transparent;
		pointer-events: none;
		opacity: 0;
		-webkit-appearance: none;
		appearance: none;
	}

	#q8kart-shop-mobile-bar > form.woocommerce-ordering.q8kart-shop-mobile-bar__ordering-form .select2 {
		display: none !important;
	}

	#q8kart-shop-mobile-bar .q8kart-shop-mobile-bar__text {
		text-transform: none;
	}

	#q8kart-shop-mobile-bar .q8kart-shop-mobile-bar__ico {
		display: flex;
		align-items: center;
		justify-content: center;
		flex: 0 0 auto;
	}

	#q8kart-shop-mobile-bar .q8kart-shop-mobile-bar__ico-img {
		display: block;
		width: 18px;
		height: 18px;
		object-fit: contain;
		pointer-events: none;
	}

	/* Full-width filter drawer (Flatsome off-canvas) + slide up from bottom */
	body.q8kart-shop-mobile-pill.woocommerce-page .off-canvas-left .mfp-content,
	body.q8kart-shop-mobile-pill.woocommerce-page .off-canvas-right .mfp-content {
		width: 100vw !important;
		max-width: 100vw !important;
	}

	body.q8kart-shop-mobile-pill .mfp-content #shop-sidebar {
		width: 100%;
		min-height: 100%;
		box-sizing: border-box;
	}

	html.mfp-open body.q8kart-shop-mobile-pill.woocommerce-page .mfp-wrap .mfp-content:has(#shop-sidebar) {
		transform: translate3d(0, 100%, 0) !important;
		transition: transform 0.36s cubic-bezier(0.32, 0.72, 0, 1), opacity 0.22s ease !important;
	}

	html.mfp-open body.q8kart-shop-mobile-pill.woocommerce-page .mfp-wrap.mfp-ready .mfp-content:has(#shop-sidebar) {
		transform: translate3d(0, 0, 0) !important;
		opacity: 1 !important;
	}

	html.mfp-open body.q8kart-shop-mobile-pill.woocommerce-page .mfp-wrap.mfp-removing .mfp-content:has(#shop-sidebar) {
		transform: translate3d(0, 100%, 0) !important;
		opacity: 0.9 !important;
	}

	@media (prefers-reduced-motion: reduce) {
		html.mfp-open body.q8kart-shop-mobile-pill.woocommerce-page .mfp-wrap .mfp-content:has(#shop-sidebar) {
			transition-duration: 0.01ms !important;
		}
	}

	/* Sort: bottom sheet (opened from pill) */
	body.q8kart-sort-sheet-open {
		overflow: hidden;
	}

	.q8kart-shop-sort-sheet {
		position: fixed;
		inset: 0;
		z-index: 10050;
		visibility: hidden;
		pointer-events: none;
		opacity: 0;
		transition: opacity 0.22s ease;
	}

	.q8kart-shop-sort-sheet--open {
		visibility: visible;
		pointer-events: auto;
		opacity: 1;
	}

	.q8kart-shop-sort-sheet__backdrop {
		position: absolute;
		inset: 0;
		background: rgba(0, 0, 0, 0.45);
	}

	.q8kart-shop-sort-sheet__panel {
		position: absolute;
		left: 0;
		right: 0;
		bottom: 0;
		max-height: min(82vh, 32rem);
		display: flex;
		flex-direction: column;
		background: #fff;
		color: #111;
		border-radius: 16px 16px 0 0;
		box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.18);
		transform: translate3d(0, 100%, 0);
		transition: transform 0.36s cubic-bezier(0.32, 0.72, 0, 1);
		padding-bottom: env(safe-area-inset-bottom, 0px);
	}

	.q8kart-shop-sort-sheet--open .q8kart-shop-sort-sheet__panel {
		transform: translate3d(0, 0, 0);
	}

	.q8kart-shop-sort-sheet__grab {
		width: 40px;
		height: 4px;
		border-radius: 4px;
		background: rgba(0, 0, 0, 0.12);
		margin: 10px auto 6px;
		flex-shrink: 0;
	}

	.q8kart-shop-sort-sheet__head {
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 12px;
		padding: 4px 12px 12px;
		border-bottom: 1px solid rgba(0, 0, 0, 0.08);
		flex-shrink: 0;
	}

	.q8kart-shop-sort-sheet__title {
		margin: 0;
		font-size: 1rem;
		font-weight: 700;
	}

	.q8kart-shop-sort-sheet__close {
		border: 0;
		background: transparent;
		color: #333;
		font-size: 1.5rem;
		line-height: 1;
		padding: 4px 10px;
		cursor: pointer;
		border-radius: 8px;
		-webkit-tap-highlight-color: transparent;
	}

	.q8kart-shop-sort-sheet__close:active {
		background: rgba(0, 0, 0, 0.06);
	}

	.q8kart-shop-sort-sheet__list {
		list-style: none;
		margin: 0;
		padding: 8px 0 calc(12px + env(safe-area-inset-bottom, 0px));
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
	}

	.q8kart-shop-sort-sheet__item {
		margin: 0;
		padding: 0;
	}

	.q8kart-shop-sort-sheet__opt {
		display: block;
		width: 100%;
		text-align: left;
		padding: 14px 18px;
		border: 0;
		background: transparent;
		font-size: 0.9375rem;
		color: #222;
		cursor: pointer;
		-webkit-tap-highlight-color: transparent;
	}

	.q8kart-shop-sort-sheet__opt:active {
		background: rgba(0, 0, 0, 0.05);
	}

	.q8kart-shop-sort-sheet__opt.is-active {
		font-weight: 700;
		color: var(--fs-color-primary, #2e1a6d);
	}

	@media (prefers-reduced-motion: reduce) {
		.q8kart-shop-sort-sheet,
		.q8kart-shop-sort-sheet__panel {
			transition-duration: 0.01ms;
		}
	}
}
