WooCommerce Avada: Making 2 Columns the Same Height (Finally!)
Are you struggling to get your WooCommerce product columns looking consistent and professional in your Avada theme? Nothing’s more frustrating than uneven columns making your store look messy and amateurish. This guide will walk you through several methods to ensure those columns are perfectly aligned, giving your visitors a visually appealing shopping experience. We’ll focus on getting two columns looking the same height, a common issue with varied product descriptions or images.
Why is this Important?
Imagine walking into a physical store where shelves are uneven and products are haphazardly displayed. It wouldn’t inspire confidence, right? The same principle applies online. Consistent column heights create a cleaner, more professional look, leading to:
- Improved User Experience: A visually appealing website is easier to navigate and more enjoyable to browse.
- Increased Trust: A professional design builds trust with potential customers.
- Better Conversion Rates: If your products are presented well, people are more likely to buy them.
- `.fusion-column`
- `.fusion-column-wrapper`
- `.fusion-layout-column`
- `.col-lg-6` (Or similar, indicating column width)
- Avada > Theme Options > Custom CSS
- Or, if you’re using a child theme, you can add the CSS to your child theme’s `style.css` file. Using a child theme is *strongly* recommended for any custom modifications.
- `.fusion-row`: This is your container element’s class. Replace this with the actual class name you found in the Inspect Element tool.
- `display: flex;`: This tells the browser to use Flexbox layout.
- `flex-wrap: wrap;`: This ensures that columns wrap to the next line on smaller screens. Crucial for responsiveness.
- `.fusion-row > .fusion-column`: This targets *direct* child columns within the container. Replace `.fusion-column` with the actual class name of your columns.
- `display: flex;` and `flex-direction: column;`: This sets each column as a flex container with a vertical orientation.
- `.fusion-row > .fusion-column > *`: This targets all *direct* children within each column.
- `flex: 1;` This causes the children of the column to expand equally to fill all the available space.
- `margin-bottom: 0 !important;`: This attempts to override any default bottom margins that may be pushing elements around and causing unevenness. You might need to adjust this based on your theme’s CSS.
- Responsiveness: The `flex-wrap: wrap` property is essential for responsiveness. Without it, your columns might not stack correctly on smaller screens.
- Specificity: The CSS selectors might need adjustment depending on your Avada theme’s structure and any custom modifications you’ve made. The Inspect Element tool is your best friend!
- Image Sizes: Uneven column heights can sometimes be caused by inconsistent image sizes. Make sure your product images are all the same dimensions or have a consistent aspect ratio. You can configure WooCommerce image sizes in Appearance > Customize > WooCommerce > Product Images. Regenerate your thumbnails after changing the image sizes to ensure they are applied to all products.
- Margins and Padding: Pay attention to margins and padding applied to elements *within* the columns. These can also contribute to uneven heights. You might need to adjust these using custom CSS as well.
- `document.addEventListener(‘DOMContentLoaded’, function() { … });`: This ensures the JavaScript code runs after the page has fully loaded.
- `document.querySelectorAll(‘.fusion-column’);`: This selects all the column elements. Replace `.fusion-column` with the actual CSS selector for your columns.
- The code iterates through the columns, finds the tallest one, and then sets the height of all other columns to match.
- `window.addEventListener(‘resize’, equalizeColumnHeights);`: This recalculates the heights when the window is resized, ensuring responsiveness.
- Performance: JavaScript adds extra processing to the browser, potentially slowing down your website.
- Layout Shifts: The columns might initially load with uneven heights and then shift to the correct heights after the JavaScript runs, creating a jarring visual effect.
- Complexity: JavaScript introduces more code and potential points of failure compared to CSS.
- Clear Your Cache: After making changes to your CSS or JavaScript, always clear your browser cache and any website caching plugins.
- Inspect Element: The Inspect Element tool is your best friend for debugging. Use it to see which CSS styles are being applied and identify any conflicting styles.
- Test on Different Devices: Make sure your solution works correctly on different devices and screen sizes (desktop, tablet, mobile).
- Use a Child Theme: Always make custom modifications to your theme using a child theme to avoid losing your changes when you update the parent theme.
Let’s dive in!
Method 1: Using Avada’s Column Equal Heights Option (The Easiest!)
Avada often provides the simplest solution. Check if this option is available *before* diving into code.
1. Edit your Container or Section: Open the page where your WooCommerce products are displayed using the Avada Builder. This is usually your Shop page or a custom page you’ve built.
2. Select the Container/Section: Find the container or section holding the columns you want to equalize.
3. Look for the “Equal Column Heights” Option: Within the container/section’s options, look for a setting like “Equal Column Heights” or “Match Heights of Columns.” It might be under the “Design” or “Extras” tab.
4. Enable it! Simply switch it on. Save your changes and refresh your page.
This is the easiest and most recommended method if available. Avada often handles the CSS behind the scenes for you.
Method 2: Custom CSS to the Rescue! (If Method 1 Fails)
If Avada’s built-in option isn’t working as expected or is unavailable in your version, custom CSS is your next best bet.
Understanding the CSS Approach:
We’ll use CSS to make both columns adopt the height of the taller column. We need to identify the specific CSS classes used by Avada to target these columns.
1. Inspect Element (The Detective Work): Right-click on one of the columns in your browser and select “Inspect” or “Inspect Element.” This opens your browser’s developer tools.
2. Find the Column Classes: Look for the HTML structure that surrounds the content within each column. Pay attention to `
3. Target the Correct Parent: Find the parent element (a `
4. Add the Custom CSS: Go to your WordPress Dashboard, then:
5. Paste the following CSS code:
/* Make Avada WooCommerce Columns the Same Height */
.fusion-row { /* Replace with your parent container’s class */
display: flex;
flex-wrap: wrap; /* Important for responsiveness! */
}
.fusion-row > .fusion-column { /* Replace with your column’s class */
display: flex;
flex-direction: column;
}
.fusion-row > .fusion-column > * { /* Ensure content fills the space */
flex: 1;
margin-bottom: 0 !important; /* May need to adjust margins */
}
Explanation of the CSS:
6. Save and Refresh: Save your changes to the Theme Options (or your child theme’s `style.css` file) and refresh your WooCommerce page.
Important Considerations:
Method 3: JavaScript (Use Sparingly)
While CSS is generally preferred, JavaScript can be used as a last resort. It is less performant than CSS and can introduce layout shifts after the page loads. Use it only if the CSS approach is impossible due to complex layout or conflicting styles.
1. Identify the Columns: Use the Inspect Element tool (as described above) to identify the CSS selectors for your columns.
2. Add the JavaScript Code: Place the following JavaScript code in the “ section of your website. You can do this using a plugin like “Insert Headers and Footers” or by editing your theme’s `header.php` file (using a child theme is *crucial* here).
document.addEventListener(‘DOMContentLoaded’, function() {
function equalizeColumnHeights() {
const columns = document.querySelectorAll(‘.fusion-column’); // Replace with your actual column selector
let maxHeight = 0;
// Reset heights
columns.forEach(column => {
column.style.height = ‘auto’;
});
// Find the tallest column
columns.forEach(column => {
maxHeight = Math.max(maxHeight, column.offsetHeight);
});
// Set all columns to the tallest height
columns.forEach(column => {
column.style.height = maxHeight + ‘px’;
});
}
equalizeColumnHeights();
// Recalculate on window resize (for responsiveness)
window.addEventListener(‘resize’, equalizeColumnHeights);
});
Explanation:
Why is JavaScript a last resort?
Real-Life Examples and Troubleshooting
Example 1: Product Descriptions Causing Unevenness
If your product descriptions vary significantly in length, this is a common cause of uneven columns. The CSS solution with `display: flex` and `flex: 1` is usually very effective in this case. Ensure you’re also setting the minimum height of product images and product titles too.
Example 2: Different Number of Product Attributes
If one product has more attributes or specifications listed than another, this can also lead to unevenness. Again, `display: flex` is your friend. Also try adding a `min-height` attribute to the attribute container.
Troubleshooting Tips:
By following these steps and carefully using the Inspect Element tool, you’ll be well on your way to achieving perfectly aligned WooCommerce product columns in your Avada theme, creating a professional and engaging shopping experience for your customers. Good luck!
 
				