Welcome to the ultimate treasure trove of CSS Tricks! Whether you’re a seasoned front-end developer or just starting out, these 10 mind-blowing hacks will elevate your skills and leave you amazed at what CSS can do.
From enhancing user experience to solving complex layout issues with ease, these tips are designed to push your creativity and efficiency to the next level. Say goodbye to tedious workarounds and get ready to unlock the full power of CSS magic!
Table of Contents
1. CSS Variables Magic šØ
š” Tip: Define reusable values with –custom-properties, then use them throughout your CSS!
:root { --main-color: #ff6347; } body { background-color: var(--main-color); }
Let me explain using Proper Code:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>CSS Variables Magic šØ</title> <style> :root { --main-color: #ff6347; --accent-color: #00bfff; --text-color: #ffffff; } body { background-color: var(--main-color); color: var(--text-color); font-family: Arial, sans-serif; display: flex; justify-content: center; align-items: center; height: 100vh; margin: 0; } .box { background-color: var(--accent-color); padding: 50px; border-radius: 10px; text-align: center; font-size: 1.5em; } </style> </head> <body> <div class="box"> This box uses CSS Variables! šØ </div> </body> </html>
Output:
data:image/s3,"s3://crabby-images/90f9d/90f9d8daaaa21f86b0bfda6e07ecdf47f5485875" alt="CSS Tricks CSS Variables Magic šØ"
2. The Hidden Hover Effect šµļøāāļø
š Hover effects without adding hover in CSS? Try :not()
with child selectors for stealthy hover interactions!
button:not(:hover) { background-color: #ddd; }
Let me explain using Proper Code:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Hidden Hover Effect with :not()</title> <style> body { display: flex; justify-content: center; align-items: center; height: 100vh; background-color: #f5f5f5; } .container { display: flex; gap: 10px; } .box { width: 100px; height: 100px; background-color: #3498db; transition: background-color 0.3s ease, transform 0.3s ease; } /* The hidden hover effect */ .box:hover { transform: scale(1.1); } .box:not(:hover) { background-color: #e74c3c; /* Changes all other boxes except the hovered one */ } </style> </head> <body> <div class="container"> <div class="box"></div> <div class="box"></div> <div class="box"></div> <div class="box"></div> </div> </body> </html>
Output:
Before Hovering:
data:image/s3,"s3://crabby-images/fe874/fe874f4c45ae3cafa447320827801063f73986de" alt="css tricks The Hidden Hover Effect šµļøāāļø"
After Hovering:
data:image/s3,"s3://crabby-images/017d2/017d2ebd611023cddba2284a729602ffb5cc0bc2" alt="css tricks The Hidden Hover Effect šµļøāāļø"
Did you get it? How without using CSS Hover, we created boxes that have a Hover effect.
3. Border-Radius Hacks šÆ
š„ Want perfect circles or pill-shaped buttons? Play with percentages in border-radius to create ultra-smooth shapes!
.circle { border-radius: 50%; } .pill { border-radius: 50% / 25%; }
Let me explain using Proper Code:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Border-Radius Hacks šÆ</title> <style> body { font-family: Arial, sans-serif; background-color: #f4f4f4; display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100vh; margin: 0; gap: 20px; } .circle { width: 100px; height: 100px; background-color: #ff6347; border-radius: 50%; display: flex; justify-content: center; align-items: center; color: #fff; font-weight: bold; } .pill { width: 200px; height: 50px; background-color: #00bfff; border-radius: 50% / 25%; display: flex; justify-content: center; align-items: center; color: #fff; font-weight: bold; } </style> </head> <body> <div class="circle">ā</div> <div class="pill">Pill Shape šÆ</div> </body> </html>
Output:
data:image/s3,"s3://crabby-images/0a95e/0a95eb2a0a5feeff8d4bc5946d9a0666554b7090" alt="css tricks Border-Radius Hacks"
4. SVGs as Backgrounds š
š Ditch static images! Use inline SVGs to create scalable, sharp backgrounds without slowing your site down!
background: url('data:image/svg+xml,...');
Let me explain using Proper Code:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>SVGs as Backgrounds š</title> <style> body { font-family: Arial, sans-serif; background-color: #f4f4f4; display: flex; justify-content: center; align-items: center; height: 100vh; margin: 0; } .svg-background { width: 300px; height: 200px; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='200' viewBox='0 0 300 200'%3E%3Crect width='300' height='200' fill='%23ff6347'/%3E%3Ccircle cx='150' cy='100' r='80' fill='%23ffffff'/%3E%3C/svg%3E"); background-size: cover; background-repeat: no-repeat; display: flex; justify-content: center; align-items: center; color: #fff; font-size: 1.5em; border-radius: 10px; box-shadow: 0 4px 8px rgba(0,0,0,0.2); } </style> </head> <body> <div class="svg-background"> SVG Background š </div> </body> </html>
Output:
data:image/s3,"s3://crabby-images/74b3f/74b3f4228c3043899d6cdfe2f91f38733da620c0" alt="css tricks SVGs as Backgrounds š"
5. CSS Grid Template Magic šļø
š Create complex grid layouts with just a few lines of code. Perfect for multi-column layouts!
.container { display: grid; grid-template-columns: 1fr 2fr; }
Let me explain using Proper Code:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>CSS Grid Template Magic šļø</title> <style> body { font-family: Arial, sans-serif; padding: 20px; background-color: #f0f0f0; } .grid-container { display: grid; grid-template-columns: 1fr 2fr; gap: 10px; background-color: #fff; padding: 20px; border-radius: 8px; box-shadow: 0 2px 8px rgba(0,0,0,0.1); } .grid-item { background-color: #f08080; padding: 20px; text-align: center; font-size: 1.2em; border-radius: 5px; color: #fff; } </style> </head> <body> <h2>CSS Grid Template Magic šļø</h2> <div class="grid-container"> <div class="grid-item">1st Column</div> <div class="grid-item">2nd Column (twice as big!)</div> </div> </body> </html>
Output:
data:image/s3,"s3://crabby-images/6573f/6573fbcadead68847aa7f6f9f0a6aba81df73e39" alt="css tricks CSS Grid Template Magic šļø"
6. Clip-Path for Funky Shapes š
āļø Bored of rectangles? Use clip-path to cut your elements into triangles, circles, stars, or custom shapes!
.funky-shape { clip-path: polygon(50% 0%, 0% 100%, 100% 100%); }
Let me explain using Proper Code:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Clip-Path for Funky Shapes š</title> <style> body { display: flex; justify-content: center; align-items: center; height: 100vh; background-color: #f4f4f4; margin: 0; font-family: Arial, sans-serif; } .funky-shape { width: 200px; height: 200px; background-color: #4caf50; clip-path: polygon(50% 0%, 0% 100%, 100% 100%); display: flex; justify-content: center; align-items: center; color: #fff; font-size: 1.2em; } </style> </head> <body> <div class="funky-shape"> š Triangle </div> </body> </html>
Output:
data:image/s3,"s3://crabby-images/6c3a8/6c3a89969d62b6bd9b8f5ec3a6cd8de9601bd903" alt="css tricks Clip-Path"
7. CSS Scroll Snap š
š¢ Smooth scrolling is cool, but scroll snapping takes it to the next level! Perfect for image sliders.
.scroll-container { scroll-snap-type: x mandatory; } .scroll-item { scroll-snap-align: start; }
Let me explain using Proper Code:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Horizontal Scroll Snap Example</title> <style> body { margin: 0; padding: 0; font-family: Arial, sans-serif; } /* Scroll Container */ .scroll-container { display: flex; overflow-x: scroll; /* Enables horizontal scrolling */ scroll-snap-type: x mandatory; /* Snap points on horizontal axis */ scroll-behavior: smooth; /* Smooth scrolling behavior */ gap: 10px; /* Space between items */ padding: 20px; height: 300px; /* Set the height of the container */ } .scroll-item { flex: 0 0 60%; scroll-snap-align: start; background-color: #3498db; border-radius: 8px; margin: 10px auto; height: 100%; display: flex; justify-content: center; align-items: center; color: white; font-size: 2rem; box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Add shadow */ transition: transform 0.3s ease; /* Add smooth transition on hover */ } .scroll-item:hover { transform: scale(1.02); /* Scale up on hover */ background-color: ORANGE; } </style> </head> <body> <h2 style="padding: 20px;">Horizontal Scroll Snap Example</h2> <!-- Scrollable Container --> <div class="scroll-container"> <div class="scroll-item">Slide 1</div> <div class="scroll-item">Slide 2</div> <div class="scroll-item">Slide 3</div> <div class="scroll-item">Slide 4</div> <div class="scroll-item">Slide 5</div> </div> </body> </html>
Output:
data:image/s3,"s3://crabby-images/b4088/b408882582b27e2fbf5d4271235f4e57dc5d5342" alt="css tricks Horizental CSS Scroll Snap"
Note: Use the Keyboard Arrow keys or Touch to scroll.
8. CSS Filters for WOW Effects š
š¼ļø Apply instant visual effects with CSS filters like blur, brightness, and contrast for cool image transformations!
img { filter: blur(5px) brightness(1.2); }
Let me explain using Proper Code:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>CSS Filters for WOW Effects š</title> <style> body { display: flex; justify-content: center; align-items: center; height: 100vh; background-color: #f4f4f4; margin: 0; font-family: Arial, sans-serif; } .filter-image { width: 300px; height: 200px; transition: filter 0.3s; border-radius: 10px; box-shadow: 0 4px 8px rgba(0,0,0,0.2); } .filter-image:hover { filter: blur(5px) brightness(1.2); } </style> </head> <body> <img src="https://via.placeholder.com/300x200" alt="Placeholder Image" class="filter-image"> </body> </html>
Output:
Before Blur & Brightness Filter Applied:
data:image/s3,"s3://crabby-images/d6450/d6450adb0fccee48846b885ec51deed0786af576" alt="css tricks CSS Filters"
After Blur & Brightness Filter Applied:
data:image/s3,"s3://crabby-images/1ca5e/1ca5e9a5542e05ed70e6b1bf35065ab2b7cc1be5" alt="css tricks CSS Filters"
9. Object-Fit for Perfect Images š¼ļø
š¼ļø Ever had an image that doesn’t fit its container? With object-fit, you can maintain aspect ratio and prevent squished images!
img { object-fit: cover; }
Let me explain using Proper Code:
Output:
data:image/s3,"s3://crabby-images/19f63/19f63b97b9dcbc17e33abbbe0e9e1a3694bce13e" alt="css tricks Object-Fit for Perfect Images"
10. CSS Custom Scrollbars āØ
š ļø Bored of ugly scrollbars? Customize them with ::-webkit-scrollbar to match your siteās vibe!
::-webkit-scrollbar { width: 10px; background-color: #f5f5f5; } ::-webkit-scrollbar-thumb { background-color: #ff6347; }
Let me explain using Proper Code:
Output:
data:image/s3,"s3://crabby-images/6dd46/6dd463a454380bfe4b530bd5c317a3d6008f3c40" alt="css tricks Custom Scrollbars"
ā” Bonus Tip: Donāt forget, the most mind-blowing trick is to experiment and have fun with your front-end creations! š§āāļøāØ
Also Read:
- The Game-Changer: How Avoiding 10 Common HTML Mistakes Improves Accessibility
- Why JavaScript is the Backbone of the Web (And Why You Should Care)