SHX-Theme/assets/collage.css

203 lines
5.1 KiB
CSS

.collage-wrapper-title {
margin-top: 0;
margin-bottom: 3rem;
}
.collage {
display: grid;
}
.collage__item > * {
width: 100%;
}
.collage__item .card__content {
flex-grow: initial;
}
@media screen and (max-width: 749px) {
.collage {
grid-column-gap: var(--grid-mobile-horizontal-spacing);
grid-row-gap: var(--grid-mobile-vertical-spacing);
}
.collage--mobile {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.collage--mobile .collage__item--left:nth-child(3n - 2) {
grid-column: span 2;
}
.collage--mobile .collage__item--left:nth-child(3n - 2):nth-last-child(2) {
grid-column: span 1;
}
.collage--mobile .collage__item--left:nth-child(3n) {
grid-column-start: 2;
}
.collage--mobile .collage__item--right:nth-child(3n - 2) {
grid-column-start: 1;
}
.collage--mobile .collage__item--right:nth-child(3n - 2):last-child {
grid-column: span 2;
}
.collage--mobile .collage__item--right:nth-child(3n - 1) {
grid-column-start: 2;
}
.collage--mobile .collage__item--right:nth-child(3n) {
grid-column: 1 / span 2;
}
}
@media screen and (min-width: 750px) {
.collage {
grid-auto-flow: column;
grid-column-gap: var(--grid-desktop-horizontal-spacing);
grid-row-gap: var(--grid-desktop-vertical-spacing);
grid-template-columns: repeat(3, minmax(0, 1fr));
}
.collage__item--left:nth-child(3n - 2) {
grid-column: 1 / span 2;
grid-row: span 2;
}
.collage__item--left:nth-child(3n - 2):last-child {
grid-column: 1 / span 3;
}
.collage__item--left:nth-child(3n - 1),
.collage__item--left:nth-child(3n) {
grid-column-start: 3;
}
.collage__item--left:nth-child(3n - 1):last-child {
grid-row: span 2;
}
.collage__item--right:nth-child(3n - 2) {
grid-column: 1 / span 1;
grid-row: span 1;
}
.collage__item--right:nth-child(3n - 2):last-child {
grid-column: 1 / span 3;
}
.collage__item--right:nth-child(3n - 1) {
grid-column-start: 1;
}
.collage__item--right:nth-child(3n-1):last-child {
grid-column: span 2;
}
.collage__item--right:nth-child(3n) {
grid-column: 2 / span 2;
grid-row: span 2;
}
.collage__item--collection:only-child,
.collage__item--product:only-child {
justify-self: center;
max-width: 73rem;
width: 100%;
}
}
.collage-card {
height: 100%;
position: relative;
border-radius: var(--border-radius);
border: var(--border-width) solid rgba(var(--color-foreground), var(--border-opacity));
padding: var(--image-padding);
}
/* Needed for gradient continuity with or without animation, background-attachment: local scopes the gradient to its container which happens automatically when a transform is applied (animation on scroll) */
.collage-card.gradient {
transform: perspective(0);
}
.collage-card:after {
content: '';
position: absolute;
z-index: -1;
border-radius: var(--border-radius);
box-shadow: var(--shadow-horizontal-offset) var(--shadow-vertical-offset) var(--shadow-blur-radius)
rgba(var(--color-shadow), var(--shadow-opacity));
width: calc(var(--border-width) * 2 + 100%);
height: calc(var(--border-width) * 2 + 100%);
top: calc(var(--border-width) * -1);
left: calc(var(--border-width) * -1);
}
.collage-card.product-card-wrapper {
--border-radius: var(--product-card-corner-radius);
--border-width: var(--product-card-border-width);
--border-opacity: var(--product-card-border-opacity);
--shadow-horizontal-offset: var(--product-card-shadow-horizontal-offset);
--shadow-vertical-offset: var(--product-card-shadow-vertical-offset);
--shadow-blur-radius: var(--product-card-shadow-blur-radius);
--shadow-opacity: var(--product-card-shadow-opacity);
--shadow-visible: var(--product-card-shadow-visible);
--image-padding: var(--product-card-image-padding);
}
.collage-card .media {
height: 100%;
overflow: hidden;
border-radius: calc(var(--border-radius) - var(--border-width) - var(--image-padding));
}
.collage-card .deferred-media {
height: 100%;
overflow: visible;
}
.collage-card__link {
display: block;
height: 100%;
}
.collage-card .deferred-media__poster {
background-color: transparent;
border: 0;
}
.collage-card .deferred-media__poster:after {
content: '';
position: absolute;
z-index: 1;
outline-offset: 0.3rem;
bottom: calc(var(--border-width) * -1);
left: calc(var(--border-width) * -1);
right: calc(var(--border-width) * -1);
top: calc(var(--border-width) * -1);
}
.collage-card .deferred-media__poster:focus:after {
box-shadow: 0 0 0 0.3rem rgb(var(--color-background)), 0 0 0.5rem 0.4rem rgba(var(--color-foreground), 0.3);
outline: 0.2rem solid rgba(var(--color-foreground), 0.5);
}
.collage-card .deferred-media__poster:focus-visible:after {
box-shadow: 0 0 0 0.3rem rgb(var(--color-background)), 0 0 0.5rem 0.4rem rgba(var(--color-foreground), 0.3);
outline: 0.2rem solid rgba(var(--color-foreground), 0.5);
}
.collage-card .deferred-media__poster:focus:not(:focus-visible),
.collage-card .deferred-media__poster:focus:not(:focus-visible):after {
outline: none;
box-shadow: none;
}
.collage-card .deferred-media__poster:focus {
outline: none;
box-shadow: none;
}