/* Holy Grail Layout */
.holy-grail {
display: grid;
grid-template:
"header header header" 64px
"sidebar main aside" 1fr
"footer footer footer" 48px
/ 200px 1fr 200px;
min-height: 100vh;
gap: 1rem;
}
/* Card Grid */
.card-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
gap: 1.5rem;
}
/* Masonry-ish */
.masonry {
columns: 3 280px;
column-gap: 1.5rem;
}
.masonry > * {
break-inside: avoid;
margin-bottom: 1.5rem;
}
/* Centered hero */
.hero-center {
display: grid;
place-items: center;
min-height: 100vh;
}