.collection--tiles {
    --gutter-column: var(--space-x2);
    --ui-card-padding-override: var(--space);

    /*
    Customizable variables to override the default styles defined in the site settings:
    --collection-item-title-size,
    --collection-item-title-color,
    --collection-item-desc-size,
    --collection-item-desc-color,
    */

    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: var(--gutter-column);
}

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

.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 {
    border-radius: var(--theme-border-radius-card);
}

.collection__card > .ui-card {
    height: 100%;
    min-height: var(--collection-card-image-size);
}

.collection__card--disabled {
    opacity: 0.4;
}

.collection__tile-name {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space) var(--space-x2);
    align-items: center;
    font: var(--theme-paragraph-30);
    font-size: var(--collection-item-title-size);
    color: var(--collection-item-title-color, var(--theme-heading-color));
    letter-spacing: var(--theme-paragraph-30-letter-spacing);
    transition: opacity 0.2s ease-in;
}

.collection__tile-description {
    display: -webkit-box;
    overflow: hidden;
    font: var(--theme-paragraph-30-medium);
    font-size: var(--collection-item-desc-size);
    color: var(--collection-item-desc-color, var(--theme-text-20));
    letter-spacing: var(--theme-paragraph-30-letter-spacing);
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.collection__tile-name--bold,
.collection__tile-description--bold {
    font-weight: var(--theme-font-weight-bold);
}

.collection__tile-name--italic,
.collection__tile-description--italic {
    font-style: italic;
}

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

.ui-price--collection-tile {
    color: var(--theme-heading-color);
}

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

.collection__card-image--disabled {
    opacity: 0.4;
}

/* 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;
}

@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-no-image-size: 50px;
}

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

.collection__card-image {
    min-width: var(--collection-card-no-image-size); /* Default size for cards without images */
    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-has-image {
    min-width: var(--collection-card-image-size); /* Default size for cards with images */
}

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

.collection__card-title-container {
    display: flex;
}

.collection__card-title-wrapper {
    display: -webkit-box;
    width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    word-break: break-word;
    vertical-align: middle;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    -moz-box-orient: vertical;
}

.collection__card-inline-icon-badges-wrapper {
    display: inline-flex;
    gap: var(--space-half);
    align-items: center;
    padding-left: var(--space-half);
}

.collection__card-icon-badges-wrapper {
    display: flex;
    gap: var(--space-half);
    align-items: center;
}

.collection__card-sold-out {
    color: var(--theme-pill-normal-text);
}

.collection__card-desc {
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    display: -webkit-box;
    overflow: hidden;
    font: var(--theme-paragraph-10);
    color: var(--theme-text-20);
    letter-spacing: var(--theme-paragraph-10-letter-spacing);
    word-break: break-word;
}

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

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