/**
 * Overrides de layout responsive - Shopping Locales
 * Alta especificidad (#shopping-locales-container) para ganar sobre tema y CSS custom.
 * Este archivo se encola SIEMPRE al final de los estilos del plugin.
 *
 * @package ShoppingLocales
 * @since 1.3.1
 */

/* --- Barra de filtros: una sola fila --- */
#shopping-locales-container .shopping-locales-filters {
	display: flex !important;
	flex-direction: row !important;
	flex-wrap: nowrap !important;
	align-items: center !important;
	gap: 8px;
	width: 100%;
	min-width: 0;
}

#shopping-locales-container .shopping-locales-filters .shopping-locales-btn-marcas,
#shopping-locales-container .shopping-locales-filters .shopping-locales-filter-btn,
#shopping-locales-container .shopping-locales-filters .shopping-locales-categories-more-toggle {
	display: inline-flex !important;
	width: auto !important;
	max-width: none !important;
	flex-shrink: 0;
}

/* --- Buscador --- */
#shopping-locales-container .shopping-locales-search {
	position: relative !important;
	flex: 0 0 200px;
	width: 200px;
	max-width: 200px;
	min-width: 0;
	box-sizing: border-box;
}

#shopping-locales-container .shopping-locales-search-icon {
	position: absolute !important;
	left: 16px !important;
	top: 50% !important;
	transform: translateY(-50%) !important;
	width: 18px !important;
	height: 18px !important;
	margin: 0 !important;
	padding: 0 !important;
	pointer-events: none !important;
	z-index: 1;
}

#shopping-locales-container .shopping-locales-search-icon svg {
	width: 18px !important;
	height: 18px !important;
	display: block;
}

#shopping-locales-container .shopping-locales-search-input {
	display: block !important;
	width: 100% !important;
	padding: 10px 12px 10px 48px !important;
	box-sizing: border-box !important;
	border: none !important;
	background: transparent !important;
	min-width: 0 !important;
	line-height: 1.3;
}

#shopping-locales-container .shopping-locales-search-input::placeholder {
	color: var(--sl-text-muted, #666);
	opacity: 1;
}

/* --- Categorías visibles (desktop/tablet) --- */
#shopping-locales-container .shopping-locales-filters-categories {
	flex: 1 1 0 !important;
	min-width: 0 !important;
	max-width: 100%;
	overflow: hidden !important;
}

#shopping-locales-container .shopping-locales-filters-categories-scroll {
	display: flex !important;
	flex-wrap: nowrap !important;
	align-items: center;
	gap: 6px;
	min-width: 0;
	width: 100%;
	overflow-x: auto !important;
	overflow-y: hidden !important;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	-ms-overflow-style: none;
	padding: 2px 4px 2px 0;
}

#shopping-locales-container .shopping-locales-filters-categories-scroll::-webkit-scrollbar {
	display: none;
}

#shopping-locales-container .shopping-locales-filters-categories-scroll .shopping-locales-filter-btn {
	flex: 0 0 auto !important;
	white-space: nowrap;
}

/* --- Botón desplegable: ancho fijo, sin superponer categorías --- */
#shopping-locales-container .shopping-locales-categories-more {
	position: relative !important;
	flex: 0 0 44px !important;
	width: 44px !important;
	min-width: 44px !important;
	margin-left: 4px;
	z-index: auto;
}

#shopping-locales-container .shopping-locales-categories-more-toggle {
	width: 44px !important;
	height: 44px !important;
	min-width: 44px !important;
	padding: 0 !important;
	box-sizing: border-box !important;
	justify-content: center;
}

/* --- Carrusel desktop --- */
#shopping-locales-container .shopping-locales-carousel-wrapper {
	display: flex;
	align-items: flex-start;
	width: 100%;
	min-width: 0;
}

#shopping-locales-container .shopping-locales-carousel {
	flex: 1 1 auto;
	min-width: 0;
	width: 100%;
}

/* --- Tablet compacto --- */
@media (max-width: 1200px) {
	#shopping-locales-container .shopping-locales-search {
		flex: 0 0 170px;
		width: 170px;
		max-width: 170px;
	}

	#shopping-locales-container .shopping-locales-search-input {
		font-size: 13px !important;
		padding: 9px 10px 9px 44px !important;
	}

	#shopping-locales-container .shopping-locales-filters-categories-scroll {
		gap: 5px;
	}

	#shopping-locales-container .shopping-locales-filters-categories-scroll .shopping-locales-filter-btn {
		font-size: 11px;
		padding: 7px 10px;
	}
}

/* --- Mobile ≤ 768px: MARCAS | buscador | desplegable --- */
@media (max-width: 768px) {
	#shopping-locales-container .shopping-locales-filters {
		gap: 6px !important;
	}

	#shopping-locales-container .shopping-locales-filters-categories {
		display: none !important;
		width: 0 !important;
		min-width: 0 !important;
		max-width: 0 !important;
		overflow: hidden !important;
		flex: 0 0 0 !important;
		padding: 0 !important;
		margin: 0 !important;
	}

	#shopping-locales-container .shopping-locales-search {
		flex: 1 1 auto !important;
		width: auto !important;
		max-width: none !important;
		min-width: 0 !important;
	}

	#shopping-locales-container .shopping-locales-categories-more {
		flex: 0 0 40px !important;
		width: 40px !important;
		min-width: 40px !important;
	}

	#shopping-locales-container .shopping-locales-categories-more-toggle {
		width: 40px !important;
		height: 40px !important;
		min-width: 40px !important;
	}

	#shopping-locales-container .shopping-locales-btn-marcas {
		font-size: 11px;
		padding: 8px 12px;
	}

	#shopping-locales-container .shopping-locales-search-input {
		font-size: 12px !important;
		padding: 8px 8px 8px 42px !important;
	}

	#shopping-locales-container .shopping-locales-search-icon {
		left: 14px !important;
		width: 16px !important;
		height: 16px !important;
	}

	#shopping-locales-container .shopping-locales-search-icon svg {
		width: 16px !important;
		height: 16px !important;
	}

	/* Carrusel: scroll interno, sin overflow en el documento */
	#shopping-locales-container {
		max-width: 100% !important;
		overflow-x: hidden !important;
		box-sizing: border-box;
	}

	#shopping-locales-container .shopping-locales-carousel-wrapper {
		gap: 0 !important;
		width: 100% !important;
		max-width: 100% !important;
		overflow: hidden !important;
		padding-left: 0 !important;
		padding-right: 0 !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
	}

	#shopping-locales-container .shopping-locales-carousel-prev,
	#shopping-locales-container .shopping-locales-carousel-next {
		display: none !important;
		width: 0 !important;
		height: 0 !important;
		overflow: hidden !important;
		padding: 0 !important;
		margin: 0 !important;
		border: 0 !important;
	}

	#shopping-locales-container .shopping-locales-carousel {
		display: block !important;
		flex: none !important;
		width: 100% !important;
		max-width: 100% !important;
		min-width: 0 !important;
		overflow-x: auto !important;
		overflow-y: hidden !important;
		-webkit-overflow-scrolling: touch;
		scroll-behavior: smooth;
		scrollbar-width: none;
		-ms-overflow-style: none;
	}

	#shopping-locales-container .shopping-locales-carousel::-webkit-scrollbar {
		display: none;
	}

	#shopping-locales-container .shopping-locales-track {
		display: flex !important;
		flex-wrap: nowrap !important;
		align-items: center;
		width: max-content !important;
		max-width: none !important;
		min-width: 0 !important;
		gap: 16px !important;
		padding: 16px 0 !important;
		margin: 0 !important;
		transform: none !important;
	}

	#shopping-locales-container .shopping-locales-card {
		flex: 0 0 150px !important;
		width: 150px !important;
		max-width: 150px !important;
		min-width: 150px !important;
		box-sizing: border-box !important;
	}

	#shopping-locales-container .shopping-locales-card-circle-wrapper {
		max-width: 140px;
	}
}

@media (max-width: 480px) {
	#shopping-locales-container .shopping-locales-btn-marcas {
		font-size: 10px;
		padding: 7px 10px;
	}
}
