.collection--tiles {
    --gutter-column: var(--space-x2);
    --collection-item-title-size: var(--theme-h6-font-size);
    --collection-item-title-color: var(--theme-fill-10);
    --ui-card-padding-override: var(--space);

    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-gap: var(--gutter-column);
    row-gap: 48px;
}

@media (max-width: 991px) {
    .collection--tiles {
        grid-template-columns: 1fr;
    }
}

body:not(.is-touch-device) .collection__tile--tiles:hover {
    transition: all 0.2s ease-in;
    transform: translateY(-4px);
}

.collection__tile {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border: 1px solid var(--theme-divider-20);
    border-radius: var(--theme-border-radius-image);
}

.collection__tile,
.collection__card {
    position: relative;
    width: 100%;
    text-decoration: none;
}

.collection__card > .ui-card {
    height: 100%;
}

.collection__tile-name {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space) var(--space-x2);
    align-items: center;
    font-size: var(--collection-item-title-size);
    font-weight: var(--theme-font-weight-light);
    line-height: var(--theme-h6-line-height);
    color: var(--collection-item-title-color, var(--theme-heading-color));
    transition: opacity 0.2s ease-in;
}

.collection__tile-description {
    display: -webkit-box;
    overflow: hidden;
    color: var(--theme-text-20);
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.collection__tile-price--row {
    display: flex;
    flex-wrap: wrap-reverse;
    gap: var(--space) var(--space-x2);
    padding-top: var(--space);
    margin-top: auto;
}

.collection__tile-price--row .ui-price {
    color: var(--theme-heading-color);
}

.collection__tile-price-row  .ui-pill {
    font-weight: var(--theme-font-weight-light);
}

.collection__tile-image,
.collection__card-image {
    position: relative;
    overflow: hidden;
    transition: height 0.2s ease;
}

.collection__tile-image::after,
.collection__card-image::after {
    display: block;
    content: "";
}

/* image fit */

.collection__tile-image--fit img {
    object-fit: contain;
    object-position: center;
}

.collection__tile-image--crop img {
    object-fit: cover;
}

/* image aspect ratio */

.collection__tile-image--ratio-1_1::after,
.collection__card-image::after {
    aspect-ratio: 1 / 1;
}

.collection__tile-image--ratio-3_4::after {
    aspect-ratio: 3 / 4;
}

.collection__tile-image--ratio-4_3::after {
    aspect-ratio: 4 / 3;
}

.collection__tile-image--ratio-2_3::after {
    aspect-ratio: 2 / 3;
}

.collection__tile-image--ratio-3_2::after {
    aspect-ratio: 3 / 2;
}

.collection__tile-image--ratio-16_9::after {
    aspect-ratio: 16 / 9;
}

.collection__tile-image--ratio-9_16::after {
    aspect-ratio: 9 / 16;
}

.collection__tile-image .ui-placeholder,
.collection__tile-image img,
.collection__card-image .ui-placeholder,
.collection__card-image img {
    position: absolute;
    width: 100%;
    height: 100%;
}

.collection__card-image img {
    object-fit: cover;
    object-position: 50% 0%;
}

/* image hover effect */

.collection__tile-image--hover-fade {
    transition: opacity 0.3s;
}

.collection__tile-image--hover-fade:hover {
    opacity: 0.7;
}

.collection__tile-image--hover-zoom {
    overflow: hidden;
}

.collection__tile-image--hover-zoom img {
    transition: transform 0.3s;
}

.collection__tile-image--hover-zoom:hover img {
    transform: scale(1.3);
}

.collection__tile-image-hover {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 0.2s ease-in;
}

.collection__tile-has-secondary-image {
    background-color: var(--theme-text-10);
}

.collection__tile--has-quick-add--hover .collection__tile-image-hover,
.collection__tile-image:hover .collection__tile-image-hover {
    opacity: 1;
}

.collection__tile-quick-add {
    position: absolute;
    bottom: var(--space-x2);
    left: var(--space-x2);
    display: flex;
    flex-flow: column;
    gap: var(--space-x2);
    width: calc(100% - var(--space-x4));
    padding: var(--space-x2) var(--space-x3);
    text-align: center;
    background-color: var(--theme-body-color);
    border-radius: var(--theme-border-radius-image);
    box-shadow: var(--theme-elevation-30);
}

.collection__tile-quick-add-status {
    align-items: center;
}

.collection__tile-quick-add-loading {
    display: inline-flex;
    gap: var(--space);
    align-items: center;
}

.collection__tile-quick-add-failed {
    color: var(--theme-critical-text-color);
}

.collection__tile-quick-add .ui-carousel__header {
    display: none;
}

.collection__tile-details {
    display: flex;
    flex: 1;
    flex-flow: column;
    gap: var(--space);
    padding: var(--space-x4);
    transition: opacity 0.2s ease-in;
}

/* simple item */
.collection__tile--simple .collection__tile-details {
    position: absolute;
    bottom: 0;
    left: 0;
    align-items: center;
    width: 100%;
}

.collection__tile--simple .collection__tile-button {
    display: flex;
    justify-content: center;
    width: 100%;
}

.collection__tile--simple .collection__tile-title {
    box-sizing: border-box;
    width: calc(100% - var(--space-x6));
    padding: var(--space-x2) var(--space-x3);
    text-align: center;
    background-color: var(--theme-body-color);
    border-radius: var(--theme-border-radius-image);
}

@media (min-width: 700px) {
    .collection__tile--simple .collection__tile-title {
        width: auto;
    }
}

.collection__tile-swatches {
    position: absolute;
    left: 0;
    width: 100%;
    padding-bottom: var(--space);
    opacity: 0;
    transition: opacity 0.2s ease-in;
}

.collection__tile-swatches .form-element__label {
    font-weight: calc(var(--theme-font-weight-light) - 100);
}

@media (min-width: 700px) {
    .collection__tile--has-quick-add .collection__tile-details {
        min-height: 87px;
    }

    .collection__tile--has-quick-add--hover .collection__tile-swatches {
        opacity: 1;
    }

    .collection__tile--has-quick-add--hover .collection__tile-details > div:not(.collection__tile-swatches) {
        position: relative;
        z-index: -1;
        opacity: 0;
    }
}

.collection__tile-badges {
    display: flex;
    gap: var(--space-x2);
}

/* carousel */
.collection--carousel {
    flex-wrap: nowrap;
}

.collection__tile--carousel {
    width: calc(100vw / 12 * 8);
}

@media (min-width: 992px) {
    .collection__tile--carousel {
        /*
        * The gap within the carousel width (--collection-carousel-width)
        * gap * (columnCount - 1)
        */
        --carousel-width-total-gap: calc(
            var(--ui-carousel-gap, var(--gutter-column))
            * calc(var(--collection-carousel-count, 3) - 1)
        );

        /* Calculate the width of a tile:
        * 1. Carousel width (without gap, --carousel-width-total-gap) divided by number of columns to show
        */
        width: calc(
            calc(var(--collection-carousel-width) - var(--carousel-width-total-gap))
            / var(--collection-carousel-count, 3)
        );
    }
}

/* masonry */
.collection--masonry {
    display: grid;
    grid-template-rows: repeat(2, 1fr);
    grid-template-columns: repeat(12, 1fr);
    grid-gap: var(--space-x2);
}

.collection__tile--masonry.col {
    padding: 0;
}

.collection__tile--masonry:nth-of-type(6n+1),
.collection__tile--masonry:nth-of-type(6n+2),
.collection__tile--masonry:nth-of-type(6n+5),
.collection__tile--masonry:nth-of-type(6n+6) {
    grid-row-end: span 1;
    grid-column-end: span 3;
}

.collection__tile--masonry:nth-of-type(6n+3),
.collection__tile--masonry:nth-of-type(6n+4) {
    grid-row-end: span 2;
    grid-column-end: span 6;
}

.collection--masonry .collection__tile-image {
    width: 100%;
    height: 100%;
    margin-bottom: 0;
}

.collection__tile--masonry .collection__tile-details {
    display: none;
}

/* cards */
.collection {
    --gutter-column: var(--space-x2);
    --collection-card-image-size: 136px;
}

.collection__card.is-clickable {
    cursor: pointer;
}

.collection__card-inner {
    display: flex;
    gap: var(--space-x2);
    align-items: stretch;
}

.collection__card-image {
    min-width: var(--collection-card-image-size);
    min-height: var(--collection-card-image-size);
    margin: 0;

    /* use card radius var to have a radius proportional to the card radius */
    border-radius: calc(var(--theme-border-radius-card) - (var(--ui-card-padding-override, var(--space-x3)) / 2));
}

.collection__card-details {
    display: flex;
    flex-flow: column;
    gap: var(--space);
    width: 100%;
    padding: var(--space);
}

.collection__card-title-wrapper {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space) var(--space-x2);
    align-items: center;
    font-size: var(--theme-font-size-plus-1);
    line-height: var(--theme-font-size-plus-1-line-height);
    color: var(--theme-text-10);
}

.collection__card-desc {
    font-size: var(--theme-font-size-minus-2);
    line-height: var(--theme-font-size-minus-2-line-height);
    color: var(--theme-text-20);
}

.collection__card-desc p {
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    display: -webkit-box;
    overflow: hidden;
}

.collection__card-price {
    display: flex;
    gap: var(--space);
    margin-top: auto;
    color: var(--theme-text-10);
}

.collection__card-price .ui-price__extra::before {
    display: none;
}
